重庆分公司,新征程启航

为企业提供网站建设、域名注册、服务器等服务

Hibernate动态模型是什么

这篇文章主要介绍“Hibernate动态模型是什么”,在日常操作中,相信很多人在Hibernate动态模型是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Hibernate动态模型是什么”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

奇台网站建设公司成都创新互联公司,奇台网站设计制作,有大型网站制作公司丰富经验。已为奇台上千提供企业网站建设服务。企业网站搭建\成都外贸网站建设公司要多少钱,请找那个售后服务好的奇台做网站的公司定做!

Hibernate动态模型(Dynamic models)

注意:以下特性在当前处于试验阶段,将来可能会有变化。

运行期的持久化实体没有必要一定表示为像POJO类或JavaBean对象那样的形式。Hibernate也支持动态模型(在运行期使用Map的Map)和象DOM4J的树模型那样的实体表示。使用这种方法,你不用写持久化类,只写映射文件就行了。

Hibernate默认工作在普通POJO模式。你可以使用配置选项default_entity_mode, 对特定的SessionFactory,设置一个默认的实体表示模式。 (参见表 3.3 “ Hibernate配置属性 ”。)

下面是用Map来表示的例子。首先,在映射文件中,要声明 entity-name来代替一个类名(或作为一种附属)。

                                                                                                                              

注意:虽然是用目标类名来声明关联的,但是关联的目标类型除了是POJO之外,也可以 是一个动态的实体。

在使用dynamic-map为SessionFactory 设置了默认的实体模式之后,可以在运行期使用Map的 Map。

Session s = openSession();  Transaction tx = s.beginTransaction();  Session s = openSession();   // Create a customer  Map david = new HashMap();  david.put("name", "David");   // Create an organization  Map foobar = new HashMap();  foobar.put("name", "Foobar Inc.");   // Link both  david.put("organization", foobar);   // Save both  s.save("Customer", david);  s.save("Organization", foobar);   tx.commit();  s.close();

动态映射的好处是,变化所需要的时间少了,因为原型不需要实现实体类。然而,你无法进行 编译期的类型检查,并可能由此会处理很多的运行期异常。幸亏有了Hibernate映射,它使得数 据库的schema能容易的规格化和合理化,并允许稍后在此之上添加合适的领域模型实现。

实体表示模式也能在每个Session的基础上设置:

Session dynamicSession = pojoSession.getSession(EntityMode.MAP);   // Create a customer  Map david = new HashMap();  david.put("name", "David");  dynamicSession.save("Customer", david);  ...  dynamicSession.flush();  dynamicSession.close()  ...  // Continue on pojoSession

请注意:用EntityMode调用getSession()是在 Session的API中,而不是SessionFactory。 这样,新的Session共享底层的JDBC连接,事务,和其他的上下文信 息。这意味着,你不需要在第二个Session中调用 flush()和close(),同样的,把事务和连接的处理 交给原来的工作单元。

到此,关于“Hibernate动态模型是什么”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注创新互联网站,小编会继续努力为大家带来更多实用的文章!


文章题目:Hibernate动态模型是什么
链接分享:http://cqcxhl.com/article/pcgooe.html

其他资讯

在线咨询
服务热线
服务热线:028-86922220
TOP