Hibernate schema简单分析
创始人
2024-06-07 19:10:37
0

Hibernate有很多值得学习的地方,这里我们主要介绍Hibernate schema,包括介绍切换Schema等方面。

Hibernate schema

如果你在调用Hibernate的时候需要切换schema怎么办呢。

在oracle中,不同的用户,使用不同的schema.在Hibernate的POJO中,会指定了schema

  1.  version="1.0" encoding="utf-8"?> 
  2. "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> 
  3.  
  4.  
  5.  name="com.csc.poimanager.dao.Poi" table="POI" schema="P_BEIJING"> 
  6.  name="poiId" type="java.lang.Long"> 
  7.  name="POI_ID" precision="10" scale="0" /> 
  8.  class="increment" /> 
  9.  
  10.  name="cnName" type="java.lang.String"> 
  11.  name="CN_NAME" length="1000" /> 
  12.  
  13.  
  14.  

上面的代码部分,就指定了Schema.如果在操作的时候想切换Schema.操作如下:

默认的配置POI_BEIJING

上面的映射文件改为:

  1.  version="1.0" encoding="utf-8"?> 
  2. "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> 
  3.  
  4.  
  5.  name="com.csc.poimanager.dao.Poi" table="POI" > 
  6.  name="poiId" type="java.lang.Long"> 
  7.  name="POI_ID" precision="10" scale="0" /> 
  8.  class="increment" /> 
  9.  
  10.  name="cnName" type="java.lang.String"> 
  11.  name="CN_NAME" length="1000" /> 
  12.  
  13.  
  14.  

在操作的,可以用下面的方法来重新build你的SessionFactory

  1. public static void rebuildSessionFactoryForChangeSchema(String newSchema){  
  2. try {  
  3.  
  4. Properties p = configuration.getProperties();  
  5. System.out.println("---" + p);  
  6. p.put("hibernate.default_schema", newSchema);  
  7. sessionFactory = configuration.buildSessionFactory();  
  8. System.out.println(" change schema successfully ......... ");  
  9. } catch (Exception e) {  
  10. System.err  
  11. .println("%%%% rebuild session factory failed for changing schema %%%%");  
  12. e.printStackTrace();  
  13. }  

如果需要改变Schema,就需要在需要的时候调用此方法。

比如在SchemaAction中

  1. HibernateSessionFactory.rebuildSessionFactoryForChangeSchema("POI_SHANGHAI");  
  2.  
  3. System.out.println(" change successfully---");  
  4.  
  5. PoiDAO pd = new PoiDAO();  
  6. Transaction t =pd.getSession().beginTransaction();  
  7.  
  8. pd.save(new Poi("jsfjksdf"));  
  9. t.commit(); 

那么,原来,是向POI_BEIJING中插入数据的,变成了向POI_SHANGHAI中插入一条数据了。通过这种方法,可以实现在操作不同的Schema的时候实现切换。

问题:此处改变的是静态工厂。所以,会对所有的用户产生影响。如果不想对所有的用户改变,那么可以根据Schema的名称来取得自己对应的SessionFactoy就可以了。以上介绍Hibernate schema。

【编辑推荐】

  1. 浅析Hibernate orm框架
  2. Hibernate Callback简单概括
  3. 概述Hibernate dbcp连接池使用方法
  4. Hibernate Shard三种策略剖析
  5. 讨论Hibernate和模型对象

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...