加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java – 使用JDBC连接到不同数据库的模式

发布时间:2020-12-15 00:51:51 所属栏目:Java 来源:网络整理
导读:我正在编写一个应用程序,它必须可配置为根据客户端的想法连接到Oracle,SQL Server和 MySQL. 到目前为止,我一直在计划使用JDBC-ODBC桥,只使用不同的连接字符串连接到数据库. 我被告知这不是很有效率. 是否存在连接多个数据库系统的模式或最佳实践?或者选择使
我正在编写一个应用程序,它必须可配置为根据客户端的想法连接到Oracle,SQL Server和 MySQL.

到目前为止,我一直在计划使用JDBC-ODBC桥,只使用不同的连接字符串连接到数据库.

我被告知这不是很有效率.

>是否存在连接多个数据库系统的模式或最佳实践?或者选择使用哪个驱动程序?
>我应该配置它吗?但包括所有三个驱动程序或建立三个单独的客户?

我没有做任何复杂的事情,只是从事件流中将数据泵入(插入)到数据库中.

解决方法

我建议您将其配置为包含三个驱动程序.您可以使用这样的模式:创建一个提供连接数据库功能的超类(让我们称之为DAO).这可能是抽象的.

为要连接的每种类型的数据库创建一个具体的子类.所以你最终可能会得到MySQLDAO,MSSQLDAO和OracleDAO.每个都将加载相应的驱动程序并使用其各自的连接字符串.

使用方法getDAO(DB)创建另一个类(让我们称之为DAOFactory),该方法将根据DB的值创建DAO的实例.

所以例如(在伪代码中):

if(DB.equals("MySQL")){
    DAO = new MySQLDAO();
}
return DAO;

因此,任何需要连接到数据库的代码都将调用DAOFactory并请求DAO实例.您可以将DB值存储在外部文件(如属性文件)中,这样您就不必修改代码来更改数据库的类型.

这样,您的代码不需要知道它连接到哪种类型的数据库,如果您决定稍后再支持第四种类型的数据库,则必须再添加一个类并修改DAOFactory,而不是代码的其余部分.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读