欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

hibernate查詢緩存詳細(xì)分析

 更新時(shí)間:2017年09月07日 10:40:11   作者:動(dòng)力節(jié)點(diǎn)  
這篇文章主要介紹了hibernate查詢緩存詳細(xì)分析,包括查詢緩存配置方法及關(guān)閉二級(jí)緩存的詳細(xì)介紹,需要的朋友參考下本文吧

 一、查詢緩存配置

1、在hibernate.cfg.xml中加入查詢緩存的策略,  <propertyname="hibernate.cache.use_query_cache">true</property>      啟用查詢緩存的策略,默認(rèn)是false。 

二、關(guān)閉二級(jí)緩存,采用query.list()查詢普通屬性

代碼如下所示。

public voidtestCache1() { 
  Session session = null; 
  try { 
   session= HibernateUtils.getSession(); 
   session.beginTransaction(); 
   Listnames = session.createQuery("select s.name from Student s") 
       .setCacheable(true) 
       .list(); 
   for (int i=0;i<names.size(); i++) { 
   Stringname = (String)names.get(i); 
   System.out.println(name); 
   } 
   System.out.println("-------------------------------------------------------"); 
   //不會(huì)發(fā)出查詢語句,因?yàn)閱⒂貌樵兙彺?
   names= session.createQuery("select s.name from Student s") 
      .setCacheable(true) 
      .list(); 
   for (int i=0;i<names.size(); i++) { 
   Stringname = (String)names.get(i); 
   System.out.println(name); 
   } 
   session.getTransaction().commit(); 
  }catch(Exceptione) { 
   e.printStackTrace(); 
   session.getTransaction().rollback(); 
  }finally { 
   HibernateUtils.closeSession(session); 
  } 
 } 

我們可以看到控制臺(tái)輸出語句,僅輸出一次:Hibernate: select student0_.name as col_0_0_ fromt_student student0_ 

由此可知,我們開啟了查詢緩存,第一次進(jìn)行查詢的時(shí)候,已經(jīng)把結(jié)果放到querycache中,當(dāng)?shù)诙卧俅巫龀鱿嗤牟樵兊臅r(shí)候,就不再向數(shù)據(jù)庫(kù)發(fā)重復(fù)的sql語句了。

三、關(guān)閉二級(jí)緩存,啟用查詢緩存,采用query.list()查詢普通屬性

代碼就如下所示。

public voidtestCache2() { 
  Sessionsession = null; 
  try { 
   session= HibernateUtils.getSession(); 
   session.beginTransaction(); 
   Listnames = session.createQuery("select s.name from Student s") 
       .setCacheable(true) 
       .list(); 
   for (int i=0;i<names.size(); i++) { 
   Stringname = (String)names.get(i); 
   System.out.println(name); 
   } 
   session.getTransaction().commit(); 
  }catch(Exceptione) { 
   e.printStackTrace(); 
   session.getTransaction().rollback(); 
  }finally { 
   HibernateUtils.closeSession(session); 
  } 
  System.out.println("-------------------------------------------------------"); 
  try { 
   session= HibernateUtils.getSession(); 
   session.beginTransaction(); 
   //不會(huì)發(fā)出查詢語句,因?yàn)椴樵兙彺婧蛃ession的生命周期沒有關(guān)系 
   Listnames = session.createQuery("select s.name from Student s") 
       .setCacheable(true) 
       .list(); 
   for (int i=0;i<names.size(); i++) { 
   Stringname = (String)names.get(i); 
   System.out.println(name); 
   } 
   session.getTransaction().commit(); 
  }catch(Exceptione) { 
   e.printStackTrace(); 
   session.getTransaction().rollback(); 
  }finally { 
   HibernateUtils.closeSession(session); 
  }   
 }  

運(yùn)行結(jié)果如下所示。

控制臺(tái)打印結(jié)果:

select student0_.name as col_0_0_ fromt_student student0_
班級(jí)0的學(xué)生0
班級(jí)0的學(xué)生1
班級(jí)0的學(xué)生2
班級(jí)0的學(xué)生3
班級(jí)0的學(xué)生4
班級(jí)0的學(xué)生5…

我們可以看出,同樣,只打印一次查詢語句,如果沒有開啟查詢緩存的話,并且關(guān)閉二級(jí)緩存的情況下,還會(huì)去數(shù)據(jù)庫(kù)再查詢一遍,而我們的程序中沒有再去重復(fù)的去數(shù)據(jù)庫(kù)中查詢的原因是,當(dāng)開啟query緩存的時(shí)候,查詢緩存的生命周期與session無關(guān)。

四、關(guān)閉二級(jí)緩存,開啟查詢,采用query.iterate()查詢普通屬性

代碼如下所示。

public voidtestCache3() { 
  Sessionsession = null; 
  try { 
   session= HibernateUtils.getSession(); 
   session.beginTransaction(); 
   Iteratoriter = session.createQuery("select s.name from Student s") 
       .setCacheable(true) 
       .iterate(); 
   while(iter.hasNext()){ 
   Stringname = (String)iter.next(); 
   System.out.println(name); 
   } 
   session.getTransaction().commit(); 
  }catch(Exceptione) { 
   e.printStackTrace(); 
   session.getTransaction().rollback(); 
  }finally { 
   HibernateUtils.closeSession(session); 
  } 
  System.out.println("-------------------------------------------------------"); 
  try { 
   session= HibernateUtils.getSession(); 
   session.beginTransaction(); 
   //會(huì)發(fā)出查詢語句,query.iterate()查詢普通屬性它不會(huì)使用查詢緩存 
   //查詢緩存只對(duì)query.list()起作用 
   Iteratoriter = session.createQuery("select s.name from Student s") 
      .setCacheable(true) 
      .iterate(); 
   while(iter.hasNext()){ 
   Stringname = (String)iter.next(); 
   System.out.println(name); 
   } 
   session.getTransaction().commit(); 
  }catch(Exceptione) { 
   e.printStackTrace(); 
   session.getTransaction().rollback(); 
  }finally { 
   HibernateUtils.closeSession(session); 
  } 
  
 } 

顯控制臺(tái)顯示結(jié)果打印了兩次sql語句。

-------------------------------------------------------

Hibernate: select student0_.name as col_0_0_from t_student student0_

根據(jù)這樣的結(jié)果我們發(fā)現(xiàn),quer.iterate()查詢普通屬性它是不會(huì)使用查詢緩存,查詢緩存只對(duì)query.list()起作用。

五、關(guān)閉二級(jí)緩存,關(guān)閉查詢緩存,采用query.list()查詢實(shí)體

代碼如下所示。

public voidtestCache4() { 
  Sessionsession = null; 
  try { 
   session= HibernateUtils.getSession(); 
   session.beginTransaction(); 
   List students =session.createQuery("select s from Student s") 
       .list(); 
   for (int i=0;i<students.size(); i++) { 
   Studentstudnet = (Student)students.get(i); 
   System.out.println(studnet.getName()); 
   } 
   session.getTransaction().commit(); 
  }catch(Exceptione) { 
   e.printStackTrace(); 
   session.getTransaction().rollback(); 
  }finally { 
   HibernateUtils.closeSession(session); 
  } 
  System.out.println("-------------------------------------------------------"); 
  try { 
   session= HibernateUtils.getSession(); 
   session.beginTransaction(); 
   //會(huì)發(fā)出查詢語句,默認(rèn)query.list()每次執(zhí)行都會(huì)發(fā)出查詢語句 
   List students =session.createQuery("select s from Student s") 
       .list(); 
   for (int i=0;i<students.size(); i++) { 
   Studentstudnet = (Student)students.get(i); 
   System.out.println(studnet.getName()); 
   } 
  }catch(Exceptione) { 
   e.printStackTrace(); 
   session.getTransaction().rollback(); 
  }finally { 
   HibernateUtils.closeSession(session); 
  } 
 } 

   顯示結(jié)果如下所示。

控制臺(tái)上打印兩次sql語句。

Hibernate:select student0_.id as id0_, student0_.name as name0_, student0_.classesid asclassesid0_ from t_student student0_

班級(jí)0的學(xué)生0
班級(jí)0的學(xué)生1
班級(jí)0的學(xué)生2
班級(jí)0的學(xué)生3
班級(jí)0的學(xué)生4

由此可知,不開啟查詢緩存,默認(rèn)query.list每次執(zhí)行都會(huì)發(fā)出查詢語句。

六、關(guān)閉二級(jí)緩存,開啟查詢緩存,采用query.list()查詢實(shí)體

代碼如下所示。

Session session = null; 
  try { 
   session= HibernateUtils.getSession(); 
   session.beginTransaction(); 
   Liststudents = session.createQuery("select s from Student s") 
       .setCacheable(true) 
       .list(); 
   for (int i=0;i<students.size(); i++) { 
   Studentstudnet = (Student)students.get(i); 
   System.out.println(studnet.getName()); 
   } 
   session.getTransaction().commit(); 
  }catch(Exceptione) { 
   e.printStackTrace(); 
   session.getTransaction().rollback(); 
  }finally { 
   HibernateUtils.closeSession(session); 
  } 
  System.out.println("-------------------------------------------------------"); 
  try { 
   session= HibernateUtils.getSession(); 
   session.beginTransaction(); 
   
   //會(huì)發(fā)出n條查詢語句,因?yàn)殚_啟了查詢緩存,關(guān)閉了二級(jí)緩存,那么查詢緩存就會(huì)緩存實(shí)體對(duì)象的id 
   //第二次執(zhí)行query.list(),將查詢緩存中的id依次取出,分別到一級(jí)緩存和二級(jí)緩存中查詢相應(yīng)的實(shí)體 
   //對(duì)象,如果存在就使用緩存中的實(shí)體對(duì)象,否則根據(jù)id發(fā)出查詢學(xué)生的語句 
   Liststudents = session.createQuery("select s from Student s") 
       .setCacheable(true) 
       .list(); 
   for (int i=0;i<students.size(); i++) { 
   Studentstudnet = (Student)students.get(i); 
   System.out.println(studnet.getName()); 
   } 
  }catch(Exceptione) { 
   e.printStackTrace(); 
   session.getTransaction().rollback(); 
  }finally { 
   HibernateUtils.closeSession(session); 
  } 

控制臺(tái)打印sql如下圖所示。

在第一次查詢的時(shí)候,發(fā)出一條sql語句查詢出結(jié)果,因?yàn)槲覀冮_啟了查詢緩存,會(huì)把第一次查詢出的實(shí)體結(jié)果集的id放到查詢緩存中,第二次再次執(zhí)行query.list()的時(shí)候,會(huì)把id拿出來,到相應(yīng)的緩存去找,因?yàn)槭强鐂ession,在二級(jí)緩存中找不到,所以每次都會(huì)發(fā)出查詢語句,二級(jí)緩存中不存在,有多少個(gè)id就會(huì)發(fā)出查詢語句多少次。 

七、開啟二級(jí)緩存,開啟查詢緩存,采用query.list()查詢實(shí)體

代碼如下所示。

/** 
 * 開啟查詢,開啟二級(jí)緩存,采用query.list()查詢實(shí)體 
 * 
 * 在兩個(gè)session中發(fā)query.list()查詢 
 */ 
 public voidtestCache6() { 
  Sessionsession = null; 
  try { 
   session= HibernateUtils.getSession(); 
   session.beginTransaction(); 
   Liststudents = session.createQuery("select s from Student s") 
       .setCacheable(true) 
       .list(); 
   for (int i=0;i<students.size(); i++) { 
   Studentstudnet = (Student)students.get(i); 
   System.out.println(studnet.getName()); 
   } 
   session.getTransaction().commit(); 
  }catch(Exceptione) { 
   e.printStackTrace(); 
   session.getTransaction().rollback(); 
  }finally { 
   HibernateUtils.closeSession(session); 
  } 
  System.out.println("-------------------------------------------------------"); 
  try { 
   session= HibernateUtils.getSession(); 
   session.beginTransaction(); 
   
   //不再發(fā)出查詢語句,因?yàn)榕渲昧硕?jí)緩存和查詢緩存 
   Liststudents = session.createQuery("select s from Student s") 
       .setCacheable(true) 
       .list(); 
   for (int i=0;i<students.size(); i++) { 
   Studentstudnet = (Student)students.get(i); 
   System.out.println(studnet.getName()); 
   } 
  }catch(Exceptione) { 
   e.printStackTrace(); 
   session.getTransaction().rollback(); 
  }finally { 
   HibernateUtils.closeSession(session); 
  } 
 } 

結(jié)果如下所示

Hibernate: select student0_.id as id0_,student0_.name as name0_, student0_.classesid as classesid0_ from t_studentstudent0_

只發(fā)出一次sql請(qǐng)求,當(dāng)我們第一次執(zhí)行query.list()會(huì)放到二級(jí)緩存中,和query緩存中。當(dāng)我們第一次執(zhí)行查詢時(shí),會(huì)找到相應(yīng)的id到緩存中查找,在二級(jí)緩存中存在,則直接從二級(jí)緩存中取出數(shù)據(jù),不再向數(shù)據(jù)庫(kù)中發(fā)出sql語句。

八、查詢緩存總結(jié)

查詢緩存是緩存普通屬性結(jié)果集的,對(duì)實(shí)體對(duì)象的結(jié)果集會(huì)緩存id。查詢緩存的生命周期,當(dāng)關(guān)聯(lián)的表發(fā)生修改時(shí),查詢緩存的生命周期結(jié)束。

而開啟緩存的時(shí)候,我們就要去維護(hù)緩存,如果緩存和內(nèi)存中的數(shù)據(jù)不一致的話,和數(shù)據(jù)不同步,可能給用戶顯示的是臟數(shù)據(jù)了。所以根據(jù)需要使用緩存機(jī)制。

總結(jié)

以上所述是小編給大家介紹的hibernate查詢緩存詳細(xì)分析,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 使用Spring Boot上傳文件功能

    使用Spring Boot上傳文件功能

    上傳文件是互聯(lián)網(wǎng)中常應(yīng)用的場(chǎng)景之一,最典型的情況就是上傳頭像等,今天就帶著大家做一個(gè)Spring Boot上傳文件的小案例,感興趣的朋友跟隨腳本之家小編一起學(xué)習(xí)吧
    2018-01-01
  • 詳解MybatisPlus中@TableLogic注解的使用

    詳解MybatisPlus中@TableLogic注解的使用

    @TableLogic一般用于實(shí)現(xiàn)數(shù)據(jù)庫(kù)數(shù)據(jù)邏輯刪除,本文我們將介紹 @TableLogic 注解的用法,以及每個(gè)屬性的實(shí)際意義和用法,感興趣的可以了解一下
    2022-06-06
  • Springboot實(shí)現(xiàn)前后端分離excel下載

    Springboot實(shí)現(xiàn)前后端分離excel下載

    這篇文章主要介紹了Springboot實(shí)現(xiàn)前后端分離excel下載,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • RPC框架之Thrift的入門教程

    RPC框架之Thrift的入門教程

    Thrift是一個(gè)跨語言的服務(wù)部署框架,主要用于各個(gè)服務(wù)之間的RPC通信,支持跨語言,下面小編就來和大家講講Thrift框架的具體使用,希望對(duì)大家有所幫助
    2023-10-10
  • Java安全 ysoserial CommonsCollections2示例分析

    Java安全 ysoserial CommonsCollections2示例分析

    這篇文章主要為大家介紹了Java安全 ysoserial CommonsCollections2示例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • 關(guān)于dubbo的RPC和RESTful性能及對(duì)比

    關(guān)于dubbo的RPC和RESTful性能及對(duì)比

    這篇文章主要介紹了關(guān)于dubbo的RPC和RESTful性能及對(duì)比,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • Java動(dòng)態(tài)代理模式的深入揭秘

    Java動(dòng)態(tài)代理模式的深入揭秘

    這篇文章主要給大家介紹了關(guān)于Java動(dòng)態(tài)代理模式的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Java具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • 學(xué)習(xí)Java之異常到底該如何捕獲和處理

    學(xué)習(xí)Java之異常到底該如何捕獲和處理

    我們知道,Java的異常處理是通過5個(gè)關(guān)鍵字來實(shí)現(xiàn)的,即try、catch、throw、throws和finally,try?catch語句用于捕獲并處理異常,但具體該怎么捕獲異常,怎么拋出異常,什么時(shí)候拋,什么時(shí)候捕,感興趣的小伙伴跟著小編一起來看看吧
    2023-08-08
  • SpringBoot中web模版數(shù)據(jù)渲染展示的案例詳解

    SpringBoot中web模版數(shù)據(jù)渲染展示的案例詳解

    憑借 Spring Framework 的模塊、與你最喜歡的工具的大量集成以及插入你自己的功能的能力,Thymeleaf 是現(xiàn)代 HTML5 JVM Web 開發(fā)的理想選擇——盡管它還有更多功能,本文重點(diǎn)給大家介紹SpringBoot中web模版數(shù)據(jù)渲染展示,需要的朋友可以參考下
    2022-01-01
  • 詳解在spring boot中配置多個(gè)DispatcherServlet

    詳解在spring boot中配置多個(gè)DispatcherServlet

    本篇文章主要介紹了詳解在spring boot中配置多個(gè)DispatcherServlet,具有一定的參考價(jià)值,有興趣的可以了解一下。
    2017-03-03

最新評(píng)論