iBATIS CacheModel使用浅析

开发 后端
iBATIS CacheModel缓存系统是什么情况呢?那么对于iBATIS CacheModel的学习需要了解和注意什么呢?那么本文就向你介绍iBATIS CacheModel的相关信息。

iBATIS CacheModel的使用是什么情况呢?让我们首先从现状入手,Cache也是经常讨论的一个话题之一,在我们系统开发的过程中,总会存在着这样一类数据,它们更新频率很低,然而使用的频率却非常之高。为了提高系统性能,我们通常将此类数据装入缓存。iBATIS.NET也有自己的缓存系统。

MappedStatement的查询结果集可以根据CacheModel的值来确定它是否被装入缓存以及如何装入缓存。而iBATIS CacheModel也是在配置文件中事先定义好的。具体的定义方式如下:

  1. ﹤cacheModel id="employee-cache" implementation="LRU" readOnly="true" serialize="false"﹥  
  2.   ﹤flushInterval hours="24"/﹥  
  3.   ﹤flushOnExecute  statement="insertEmployee"/﹥  
  4.   ﹤flushOnExecute  statement="updateEmployee"/﹥  
  5.   ﹤flushOnExecute  statement="deleteEmployee"/﹥  
  6.   ﹤property name="CacheSize" value="100"/﹥  
  7. ﹤/cacheModel﹥ 

iBATIS CacheModel使用浅析配置好之后,它会创建一个名为"employee-cache"的缓存实例,implementation表示它的实现规则是LRU,即:Leaste Recently Used。iBATIS.NET还有MEMORY,FIFO几种缓存的模式。

readOnly的值说明缓存是只读的还是可读写的,如果readOnly为true,缓存就是只读,false为可读写。

serialize指示缓存是在整个Application中有效还是仅作用于当前的Session。flushInterval的值表示缓存的有效期,上面的配置中则表示改缓存每24小时清空一次,当然有效期还可以用minutes, seconds or milliseconds来表示。

flushOnExecute表示缓存将在执行了什么操作时被清空,上面的配置中表示该缓存在执行insertEmployee or updateEmployee or deleteEmployee时被清空。

CacheSize表示缓存的***条目,当超过这个值的时候就会按照implementation中定义的规则来清除相应的条目,上面配置中则表示当缓存的条目超过100时,则移出最近最少使用的条目。当我们配置好cacheModel之后就可以在statement中使用了,如下:

  1. ﹤statement id="EmployeeList" cacheModel="employee-cache"﹥  
  2.   select * from Employee  
  3. ﹤/statement﹥ 

iBATIS CacheModel的相关情况就介绍到这里,希望对你了解iBATIS CacheModel缓存系统有所帮助。

【编辑推荐】

  1. iBATIS的多对多映射配置浅析
  2. iBATIS.NET API基础浅析
  3. iBATIS映射文件基础浅谈
  4. iBATIS ParameterMap配置实例浅析
  5. iBATIS ResultMap基础浅析
责任编辑:仲衡 来源: cnblogs
相关推荐

2009-07-17 17:05:44

iBATIS缓存cacheModel

2009-07-21 11:12:00

iBATIS配置

2009-07-15 17:58:07

iBATIS 动态映射

2009-07-16 10:23:30

iBATIS工作原理

2009-07-17 10:32:45

iBATIS MapB

2009-07-20 18:00:16

iBATIS DAO事

2009-07-22 10:03:11

iBATIS Resu

2009-07-15 17:19:31

iBATIS Ecli

2009-07-16 09:14:26

iBATIS DAO

2009-07-17 09:44:40

iBATIS教程

2009-07-22 15:01:01

iBATIS SQLM

2009-07-22 16:02:14

iBATIS参数

2009-07-17 10:59:59

iBATIS接口

2009-07-22 15:21:00

iBATIS SQLM

2009-07-22 09:44:05

iBATIS Para

2009-07-16 13:08:09

iBATIS快速创建应

2009-07-15 16:42:03

iBATIS读写CLO

2009-07-15 17:01:29

iBATIS操作CLO

2009-07-15 17:41:55

iBATIS事务处理

2009-07-21 14:24:46

iBATIS教程
点赞
收藏

51CTO技术栈公众号