中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何使用Hibernate的Query cache

發布時間:2021-11-03 11:33:59 來源:億速云 閱讀:155 作者:小新 欄目:編程語言

小編給大家分享一下如何使用Hibernate的Query cache,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

老實說, 要做到在JDBC查詢之前決定哪些數據需要從JDBC來還是CACHE來不是件容易事. 但是HIBERNATE還是很好地完成了這個任務. QueryCache用來緩存查詢語句, 及查詢結果集中對象的Identifier與Type. 當再次使用已緩存的Query時, 就可以通過對象的Identifier與Type在SECOND LEVEL CACHE中查找實際的對象.

使用hibernate中的QueryCache時需要在hibernate配置文件中設置如下屬性:

< property name="cache.provider_class">        org.hibernate.cache.HashtableCacheProvider  < /property> < property name="hibernate.cache.use_query_cache">true< /property>

建立ehcache的配置文件ehcache.xml放在classpath下

< ehcache>       < diskStore path="java.io.tmpdir"/>       < defaultCache           maxElementsInMemory="10000"           eternal="false"           timeToIdleSeconds="120"           timeToLiveSeconds="120"           overflowToDisk="true"           />          < cache name="com.fhway.hibernate.bean.Employee"           maxElementsInMemory="10"           eternal="false"           timeToIdleSeconds="100"           timeToLiveSeconds="100"           overflowToDisk="false"           />          < cache name="com.fhway.hibernate.bean.Department"           maxElementsInMemory="10"           eternal="false"           timeToIdleSeconds="100"           timeToLiveSeconds="100"           overflowToDisk="false"           />       < /ehcache>

在配置文件里面要加入< cache>

< class name="com.fhway.hibernate.bean.Employee " table=" Employee ">         < cache usage="read-only"/>

可以設定的策略包括read-only、read-write、nonstrict-read-write與transactional,并不是每一個第三方快取實現都支持所有的選項,每一個選項的使用時機與支持的產品,可以直接參考Hibernate官方參考快冊的 20.2.The Second Level Cache;

在程序中需要為Query對象設置Cachable屬性:

Query query = sess.createQuery("from Employee as employee");  query.setCacheable(true);    List employees = (List) query.list();  Iterator iterator = employees.iterator();  while(iterator.hasNext()){         System.out.println((Employee) iterator.next());  }     Query query1 = sess.createQuery("from Employee as employee");  query1.setCacheable(true);    List employees1 = (List) query1.list();  Iterator iterator1 = employee1.iterator();  while(iterator1.hasNext()){         System.out.println((Employee) iterator1.next());  }  Employee goncha = (Employee) sess.load(Employee.class, "001");  System.out.println(goncha);

當你調用以上代碼時你會發現這樣的輸出:

Hibernate: select employee0_.ID as ID, employee0_.NAME as NAME0_, employee0_.DEPNO0 as DEPNO0_ from AFLYER.EMPLOYEE employee0_  com.fhway.hibernate.bean.Employee@e020c9  com.fhway.hibernate.bean.Employee@117f31e  com.fhway.hibernate.bean.Employee@bad8a8  com.fhway.hibernate.bean.Employee@104c575  com.fhway.hibernate.bean.Employee@e020c9  com.fhway.hibernate.bean.Employee@117f31e  com.fhway.hibernate.bean.Employee@bad8a8  com.fhway.hibernate.bean.Employee@104c575  com.fhway.hibernate.bean.Employee@e020c9

很顯然 該緩存的利用方式對Query和load()方式有效!
Query上有list()與iterator()方法,兩者的差別在于list()方法在讀取數據時,并不會利用到快取,而是直接再向數據庫查詢,而iterator()則將讀取到的數據寫到快取,并于讀取時再次利用。(Blob 不能使用cache)

以上是“如何使用Hibernate的Query cache”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

博野县| 天津市| 绵竹市| 安溪县| 民权县| 佳木斯市| 昌乐县| 浑源县| 娱乐| 长泰县| 普兰县| 富阳市| 铁岭市| 赤壁市| 泾源县| 三都| 丹阳市| 黄平县| 神木县| 买车| 汉沽区| 梨树县| 芜湖市| 海盐县| 阳谷县| 郑州市| 闽清县| 施甸县| 连城县| 宁安市| 阿克苏市| 黔东| 天长市| 改则县| 泗水县| 广德县| 彰化市| 沙洋县| 汽车| 绥中县| 望谟县|