利用hibernate访问不同数据库中的不同表或不同数据库中的相同表。

本人在开发过程中的解决方案,希望大家交流。
一般用myEclipse工具会自动生成Hibernate的相关文件,大致有下面几类:

(1)数据库配置文件:.cfg.xml
(2)映射文件.hbm.xml
(3)映射类:pojo
(4)会话工厂类:SessionFactory
(5)基础DAO接口:IBaseHibernateDAO
(6)DAO接口的实现基础类:BaseHibernateDAO
(7)数据访问对象:DAO。所有DAO默认继承BaseHibernateDAO

当然,不同的工具生成的文件也略有差异,但不影响实现思路。

一般工具生成的配置只针对一个数据库,所以都生成了一个数据库配置文件。
下面我以访问不同数据库中相同的表做例子,访问不同数据库的不同表原理类同。
假设有两个数据库db1和db2,两个库中都有user表,要实现对两个数据库中的表访问,操作如下:

(1)配置两个数据库配置文件:db1.cfg.xml和db2.cfg.xml,分别连接两个数据库。
(2)配置两个SessionFactory:SessionFactory_db1绑定db1.cfg.xml,SessionFactory_db2,绑定db2.cfg.xml。
(3)基础DAO接口:IBaseHibernateDAO保持不变,代码默认如下
public interface IBaseHibernateDAO {
public Session getSession( );

}

(4)DAO接口的实现基础类:BaseHibernateDAO改造后如下:

public class BaseHibernateDAO implementsIBaseHibernateDAO {

private String dbName;//要连接的数据库

// 为了保证每个DAO能够正确指定所操作的数据库,将无参构造设为私有 
private BaseHibernateDAO() { }

// 指定目标数据库的DAO构造方法 
public BaseHibernateDAO(StringdbName) {
   this.dbName = dbName;
}

//重写getSession()方法,使之能够访问不同的数据库
public Session getSession() {
   if (dbName == null) {
    return null;
   }else if (dbName.equals("db01")){   
   returnSessionFactory_db01.getSession();//连接db01库
   } else if (dbName.equals("db02")) {   
   returnSessionFactory_db02.getSession();//连接db02库
   } else {
    return null;
   }
}
}

(5)改造自动生成用户表对应的DAO——UserDAO类:即继承父类BaseHibernateDAO的有参构造。

public class UserDAOextends BaseHibernateDAO {

//因为父类将无参构造设置为了private,所以该类只能存在有参构造了。
    public UserInfoTbDAO(StringdbName) {
       super(dbName);  
    }

//以下是自动生成的代码:
    public void save(UserTb transientInstance){        
        try {
           getSession().save(transientInstance);
           log.debug("save successful");
        } catch (RuntimeException re) {
           log.error("save failed", re);
            throw re;
        }
    }
}

(6)应用层的测试

public voidtestSaveUser(UserTb user){

UserDAO userDao_1 = newUserDAO("db01");//得到db01库的DAO
UserDAO userDao_2 = new UserDAO("db02");//得到db02库的DAO

//假设两个库中的数据要同步更新(实际操作中应该加入事务控制)
userDao_1.save();//更新01库
userDao_2.save();//更新02库

}

(7)总结:
优点:
1.代码改动比较小,能充分利用工具生成的代码。
2.结构简单,访问灵活。
3.访问不同库的同一个表,只需一个DAO,一个pojo,无需写额外代码。

缺点:
1.每次连接数据库时都要指定访问的数据库。
2.为了有效指定数据库逻辑名,和利于维护,就得“db01”这样的字符串设置为全局的final变量,或者弄

一个DAO工厂来产生不同的DAO实例。

另一种方法:
上面的方法是改造了DAO的构造方法。也可以改造getSession()方法,这样透明度更高,但略欠灵活。

本人刚刚接触Hibernate,不知以上设计是否妥当,望高手指点一二。

Hibernate 连接访问多个数据库(含访问不同数据库的相同表)(转)的更多相关文章

  1. ADO.NET 连接方式和非链接方式访问数据库

    一.//连接方式访问数据库的主要步骤(利用DataReader对象实现数据库连接模式) 1.创建连接对象(连接字符串) SqlConnection con = new SqlConnection(Co ...

  2. Spring框架中 配置c3p0连接池 完成对数据库的访问

    开发准备: 1.导入jar包: ioc基本jar jdbcTemplate基本jar c3p0基本jar 别忘了mysql数据库驱动jar 原始程序代码:不使用配置文件方式(IOC)生成访问数据库对象 ...

  3. 前段时间,接手一个项目使用的是原始的jdbc作为数据库的访问,发布到服务器上在运行了一段时间之后总是会出现无法访问的情况,登录到服务器,查看tomcat日志发现总是报如下的错误。    Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: Data source rejected est

    前段时间,接手一个项目使用的是原始的jdbc作为数据库的访问,发布到服务器上在运行了一段时间之后总是会出现无法访问的情况,登录到服务器,查看tomcat日志发现总是报如下的错误. Caused by: ...

  4. 数据库访问优化漏斗法则- 四、减少数据库服务器CPU运算

    数据库访问优化漏斗法则这个优化法则归纳为5个层次:1.减少数据访问次数(减少磁盘访问)2.返回更少数据(减少网络传输或磁盘访问)3.减少交互次数(减少网络传输)4.减少服务器CPU开销(减少CPU及内 ...

  5. SpringBoot 整合 hibernate 连接 Mysql 数据库

    前一篇搭建了一个简易的 SpringBoot Web 项目,最重要的一步连接数据库执行增删改查命令! 经过了一天的摸爬滚打,终于成功返回数据! 因为原来项目使用的 SpringMVC + Hibern ...

  6. 【问题&解决】试用版SQL Server 2008 R2 提示评估期已过,数据库不能访问解决办法

    因为以前一直是试用版,重启服务器之后,突然数据库不能访问,提示评估期已过,都快吓死了.还好找到了解决办法特copy解决步骤如下: (笔者用的是企业版: R88PF-GMCFT-KM2KR-4R7GB- ...

  7. 走向DBA[MSSQL篇] 从SQL语句的角度 提高数据库的访问性能

    原文:走向DBA[MSSQL篇] 从SQL语句的角度 提高数据库的访问性能 最近公司来一个非常虎的dba  10几年的经验 这里就称之为蔡老师吧 在征得我们蔡老同意的前提下  我们来分享一下蔡老给我们 ...

  8. 访问内网中的sql server数据库的简便方法

    前言: 有时候我们要访问局域网内的 sql server服务器,比如测试环境数据库在公司内网,回到家或在客户现场要连接内网中的数据库 第一步:假如可以连接局域网的数据库 192.168.150.129 ...

  9. 记一次MySQL数据库拒绝访问的解决过程

    问题背景 用wordpress搭博客,数据库采用MySQL.为了调试方便,创建账户my_account ,允许它从任意主机访问数据库. CREATE USER `my_account`@'%' IDE ...

随机推荐

  1. jstat 使用日志

    如何判断JVM是否存在内存问题呢?如何判断JVM垃圾回收是否正常?一般的top指令基本上满足不了这样的需求,因为它主要监控的是总体的系统资源,很难定位到java应用程序. Jstat是JDK自带的一个 ...

  2. 如何处理Android中的防缓冲区溢出技术

    [51CTO专稿]本文将具体介绍Android中的防缓冲区溢出技术的来龙去脉. 1.什么是ASLR? ASLR(Address space layout randomization)是一种针对缓冲区溢 ...

  3. Android使用OKHttp库实现视频文件的上传到服务器

    目录 1 服务器接口简介 2 Android端代码实现 2.1 xml布局文件 2.2 Activity类 2.3 Okhttp网络通信类 1 服务器接口简介 此处我使用的服务器接口是使用Flask编 ...

  4. TxQueryRunner-JDBC小工具

    1.TxQueryRunner的简介(需要相关jar包的请留言) TxQueryRunner类是common-dbutils下QueryRunner的子类,是用来简化JDBC操作的,所以要导入comm ...

  5. Atlas:ERROR 1105 (HY000): #07000Proxy Warning - IP Forbidden

    1:遇到一个奇怪的问题 Atlas的管理接口正常 添加一个client之后save config mysql -uroot -p -P1234 -h127.0.0.1 报错了:ERROR 1105 ( ...

  6. Echarts折线图点击事件

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...

  7. XML文件生成C++代码(基于pugixml)

    简述 在一个项目中需要用到XML的解析和生成,知乎上有人推荐rapidxml和pugixml等库.RapidXML一看库还比较大,就先研究一下pugixml了. 因为对解析XML的需求不大(都是一些很 ...

  8. LVM逻辑卷管理测试——创建逻辑卷

    虚拟机里再添加两块硬盘,如下所示: 启动系统后,我们可以看到新添加的两块硬盘为/dev/sdb和/dev/sdc.每个2GB. [root@lxjtest ~]# fdisk -l Disk /dev ...

  9. PL/SQL12中文版

    PLSQL12,界面优化很不错,更加美观,直接集成中文语言!,更加艳丽 01.界面 02.注册码 注意:有能力的还是购买付费版的,付费是对软件的高度认可和支持 12.0.3.1821 64bit: 注 ...

  10. Openwrt中用iftop查看网络流量情况

    iftop可以查看指定网卡上的流量情况, 命令说明 iftop: display bandwidth usage on an interface by host Synopsis: iftop -h ...