當(dāng)前位置:首頁(yè)文章首頁(yè) IT學(xué)院 IT技術(shù)

為了噴mybatis我下載了mybatis源碼

作者:  來(lái)源:  發(fā)布時(shí)間:2011-12-10 12:14:09  點(diǎn)擊:

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

 

看了下mybatis的高速緩存的討論。。。這部分無(wú)不例外的在分享緩存的配置。。。包括緩存實(shí)現(xiàn)。。。緩存過期策略。。。

 

LRU。。。FIFO。。。

 

如果說在xml里面寫sql。。并且在上一堆dtd描述。。并且聲稱這樣便于dba維護(hù)sql。?梢灾苯影褜懞玫膕ql copy到xml里面去。。可以統(tǒng)一管理。 好吧,這些都屬于個(gè)人習(xí)慣,無(wú)所謂。

只不過我在想把這些sql變成方法,例如最簡(jiǎn)單的一個(gè):

 

  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. }

 

 

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

 

。。。。。。。。。

作為一個(gè)ORM框架,除了面向?qū)ο蟛樵?如JPA之類的,還有一個(gè)不得不提的東西:緩存。

 

在我為緩存頭痛的時(shí)候,我努力的尋找mybatis緩存的做法。畢竟這么多人使用的框架一定可以學(xué)習(xí)一下緩存的實(shí)現(xiàn)。

 

在我輸入關(guān)鍵詞:ibatis 緩存/mybatis 緩存 看過基本上找到并且有時(shí)間去看的文章之后,我心里產(chǎn)生了一個(gè)疑問:為什么這些人來(lái)來(lái)去去都是講的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. }  

 

 當(dāng)然,還有不少人畫了一些UML例圖來(lái)給苦難大眾講解 CachingExecutor是如何工作的。

文章評(píng)論

軟件按字母排列: 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