Hibernate对数据索引进行缓存

Hibernate数据索引还是比较常用的,于是我研究了一下Hibernate数据索引,在这里拿出来和大家分享一下,希望对大家有用。

创新互联公司从2013年成立,是专业互联网技术服务公司,拥有项目成都网站制作、做网站、外贸营销网站建设网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元邵武做网站,已为上家服务,为邵武各地企业和个人服务,联系电话:028-86922220

本文我们引入了一个全新的概念——Hibernate数据索引,下面我们首先将接一下什么是数据索引。在Hibernate中对集合类型进行缓存时,是分两部分进行缓存的,首先缓存集合中所有实体的id列表,然后缓存实体对象,这些实体对象的id列表,就是所谓的数据索引。当查找数据索引时,如果没有找到对应的数据索引,这时就会一条select SQL的执行,获得符合条件的数据,并构造实体对象集合和数据索引,然后返回实体对象的集合,并且将实体对象和数据索引纳入Hibernate的缓存之中。另一方面,如果找到对应的数据索引,则从数据索引中取出id列表,然后根据id在缓存中查找对应的实体,如果找到就从缓存中返回,如果没有找到,在发起select SQL查询。在这里我们看出了另外一个问题,这个问题可能会对性能产生影响,这就是集合类型的缓存策略。如果我们如下配置集合类型:

 
 
 
  1.  name=”com.neusoft.entity.User” table=”user”>
  2.  name=”addresses” table=”address” lazy=”true” inverse=”true”>
  3.  usage=”read-only”/>
  4.  column=”user_id”/>
  5.  class=”com.neusoft.entity.Arrderss”/>

这里我们应用了配置,如果采用这种策略来配置集合类型,Hibernate数据索引进行缓存,而不会对集合中的实体对象进行缓存。如上配置我们运行下面的代码:

 
 
 
  1. User user=(User)session.load(User.class,”1”);
  2. Collection addset=user.getAddresses();
  3. Iterator it=addset.iterator();
  4. while(it.hasNext()){
  5. Address address=(Address)it.next()
  6. System.out.println(address.getAddress());
  7. }
  8. System.out.println(“Second query……”);
  9. User user2=(User)session.load(User.class,”1”);
  10. Collection it2=user2.getAddresses();
  11. while(it2.hasNext()){
  12. Address address2=(Address)it2.next();
  13. System.out.println(address2.getAddress());
  14. }

运行这段代码,会得到类似下面的输出:

 
 
 
  1. Select * from user where id=’1’;
  2. Select * from address where user_id=’1’;
  3. Tianjin
  4. Dalian
  5. Second query……
  6. Select * from address where id=’1’;
  7. Select * from address where id=’2’;
  8. Tianjin
  9. Dalian

我们看到,当第二次执行查询时,执行了两条对address表的查询操作,为什么会这样?这是因为当***次加载实体后,根据集合类型缓存策略的配置,只对集合数据索引进行了缓存,而并没有对集合中的实体对象进行缓存,所以在第二次再次加载实体时,Hibernate找到了对应实体的数据索引,但是根据数据索引,却无法在缓存中找到对应的实体,所以Hibernate数据索引发起了两条select SQL的查询操作,这里造成了对性能的浪费,怎样才能避免这种情况呢?我们必须对集合类型中的实体也指定缓存策略,所以我们要如下对集合类型进行配置:

 
 
 
  1.  name=”com.neusoft.entity.User” table=”user”>
  2.  name=”addresses” table=”address” lazy=”true” inverse=”true”>
  3.  usage=”read-write”/>
  4.  column=”user_id”/>
  5.  class=”com.neusoft.entity.Arrderss”/>

此时Hibernate会对集合类型中的实体也进行缓存,如果根据这个配置再次运行上面的代码,将会得到类似如下的输出:

 
 
 
  1. Select * from user where id=’1’;
  2. Select * from address where user_id=’1’;
  3. Tianjin
  4. Dalian
  5. Second query……
  6. Tianjin
  7. Dalian

这时将不会再有根据数据索引进行查询的SQL语句,因为此时可以直接从缓存中获得集合类型中存放的实体对象。

分享文章:Hibernate对数据索引进行缓存
文章分享:http://www.shufengxianlan.com/qtweb/news14/96464.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联