日韩精品中文字幕一区二区-日韩精品中文字幕一区-日韩精品中文字幕视频-日韩精品在线一区二区三区-第一页在线-第一福利视频

當前位置:首頁文章首頁 IT學院 IT技術

為了噴mybatis我下載了mybatis源碼

作者:  來源:  發布時間:2011-12-10 12:14:09  點擊:

久聞mybatis/ibatis大名今天終于爆發了,找了一堆mybatis的討論。。。這部分大多是關乎sql寫在xml之類的

 

看了下mybatis的高速緩存的討論。。。這部分無不例外的在分享緩存的配置。。。包括緩存實現。。。緩存過期策略。。。

 

LRU。。。FIFO。。。

 

如果說在xml里面寫sql。。并且在上一堆dtd描述。。并且聲稱這樣便于dba維護sql。。可以直接把寫好的sql copy到xml里面去。。可以統一管理。 好吧,這些都屬于個人習慣,無所謂。

只不過我在想把這些sql變成方法,例如最簡單的一個:

 

  1. <select id=”getUserList” resultMap="UserResult" cacheModel=”user-cache”>  
  2.     select * from USER  
  3. </select> 
  4. 變成:
  5. public UserResult getUserList(){
  6. return baseDao.find("select * from USER");
  7. }

 

 

我了解的太少,還沒能看出這樣有什么分別。關于這個,我只是有點點疑惑。(當然,你可以把這些寫在一個類里面,便于你們的DBA維護)

 

。。。。。。。。。

作為一個ORM框架,除了面向對象查詢 如JPA之類的,還有一個不得不提的東西:緩存。

 

在我為緩存頭痛的時候,我努力的尋找mybatis緩存的做法。畢竟這么多人使用的框架一定可以學習一下緩存的實現。

 

在我輸入關鍵詞:ibatis 緩存/mybatis 緩存 看過基本上找到并且有時間去看的文章之后,我心里產生了一個疑問:為什么這些人來來去去都是講的LRU、FIFO這些東西,或者貼出了這么一段精妙絕倫的代碼:

 

 

Java代碼  
  1. public List query(MappedStatement ms, Object parameterObject, RowBounds rowBounds, ResultHandler resultHandler) throws SQLException {  
  2.   if (ms != null) {  
  3.     Cache cache = ms.getCache();  
  4.     if (cache != null) {  
  5.       flushCacheIfRequired(ms);  
  6.       cache.getReadWriteLock().readLock().lock();  
  7.       try {  
  8.         if (ms.isUseCache() && resultHandler == null) {  
  9.           CacheKey key = createCacheKey(ms, parameterObject, rowBounds);  
  10.           final List cachedList = (List) cache.getObject(key);  
  11.           if (cachedList != null) {  
  12.             return cachedList;  
  13.           } else {  
  14.             List list = delegate.query(ms, parameterObject, rowBounds, resultHandler);  
  15.             tcm.putObject(cache, key, list);  
  16.             return list;  
  17.           }  
  18.         } else {  
  19.           return delegate.query(ms, parameterObject, rowBounds, resultHandler);  
  20.         }  
  21.       } finally {  
  22.         cache.getReadWriteLock().readLock().unlock();  
  23.       }  
  24.     }  
  25.   }  
  26.   return delegate.query(ms, parameterObject, rowBounds, resultHandler);  
  27. }  

 

 當然,還有不少人畫了一些UML例圖來給苦難大眾講解 CachingExecutor是如何工作的。

首頁 上一頁 [1] [2] [3]  下一頁 尾頁

文章評論

軟件按字母排列: A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
主站蜘蛛池模板: 《重紫》电视剧| 谍变1939电视剧剧情介绍| 汤唯惊艳写真集| 西游记续集演员表| 电影生化危机4| 电影《地狱天堂》鬼片| 林丹出轨视频| 关于想象的作文| 卧虎演员表| 王顺明| 采茶舞曲民乐合奏| 泰国av| 楚青丝完美人生免费阅读| 疯狂72小时演员表| 老闺蜜电视剧免费观看完整版高清 | 美女上厕所| 新红楼梦惊艳版| 极寒复出| 误杀2演员表| 圣少女第1集分集剧情| 马会传真论坛13297соm查询官网| 可爱的萝拉| 六年级五单元作文| 亚新| 三寸天堂简谱| 宇宙魔方| 艾娜| 山西少儿频道| 美国伦理三颗熟樱桃| 适度水解奶粉有哪些| 战无双| 听鬼故事长篇超吓人2000字| 夫妻性视频| 肉体| 重启之极海听雷2免费版在线播放 北风那个吹在线观看免费完整版 出轨的女人电影 | 王茜华泳装照片高清| 高岛真一| 夫妻的世界韩国电影| 陈宝莲拍过的电影| 湖北经视频道| 免费看污污|