摘自:
http://blog.sina.com.cn/s/blog_5f6a2a1d0100druo.html
先看一个实例:
<cacheModel id="user-cache" type="LRU" readOnly="true" serialize="false">
<flushInterval hours="24"/>
<flushOnExecute statement="insertUser"/>
<flushOnExecute statement="updateUser"/>
<flushOnExecute statement="deleteUser"/>
<property.name="cache-size" value="1000"/>
</cacheModel>
3个属性:
1、type指定使用“近期最少使用”(LRU)实现。
2、属性readOnly如果不写,默认是true,这时的缓存效果无疑最好,因为系统不需要考虑更新操作引起缓存与实际数据不一致的问题,只读缓存的例子是固化到数据库中的一些配置参数表。但是,通常我们想缓存的数据是需要增删改的,这时务必记得要加上 readOnly = "false";
3、属性serialize,如果不写,默认为false, 将它设为true,可以提高整体应用(而不仅仅是每个Session)的性能。 这种缓存为每一个Session返回缓存对象不同的实例(复本)。因此每一个Session都可以安全修改返回的对象. 注意,此时readOnly必须为false。如果你把它设为 true ,记得检查两件事,一件事是缓存中存放的对象(你想查询的POJO)必须是可序列化的, 即实现Serializable接口。如果你有一个复杂对象属性,它也必须满足这个规则,你的整个对象树必须是可序列化的。另一件事是关闭sql-map-config中的延迟加载属性,即lazyload=false,原因是,它使用了动态代理机制, 那个代理对象并不是Serializable的。
3个子元素:
1、根据flushInterval元素的内容,上面的例子每24小时刷新一次。一个cacheModel只能有一个flushInterval,可以使用hours、minutes、seconds、milliseconds来设定。
2、cacheModel可以定义任意多的flushOnExecute元素。当insertUser,updateUser,deleteUser的Mapped Statement执行时,缓存也被刷新。
3、某些cacheModel的实现可能需要另外的属性,如上面的cache-size属性,在LRU Cache Model中,cache-size指定了缓存储存的项数。
一旦配置了cache model,你可以指定mapped statement使用的Cache Model,例如:
<statement id="getUserList" cacheModel="user-cache">
select * from user
</statement>
type的3种实现
MEMORY 没有统一的对象重用模式的应用,或内存不足的应用。
<property name="reference-type" value="WEAK"/>
WEAK是默认,大多数情况下是最好的选择,能大大提高查用查询的性能,但对于当前不被使用的查询结果数据,将被清除以释放内存来分配其他对象。
LRU 实现用近期最少使用的原则来确定如何从Cache中清除对象。对于较长的时间内,一些用户经常使用某些特定对象的情况(例如,在PaginatedList和常用的查询关键字结果集中翻页),LRU Cache是不错的选择。
<property name="size" value="1000"/>
size必须为整数,代表保存在Cache的中对象的最大数目。因此不要Cache太多的对象,以免内存不足。
FIFO 实现用先进先出的原则来确定如何从Cache中清除对象。对于短时间内持续引用特定的查询而后很可能不再使用的情况,FIFO是很好的选择。
根据个人实践,内存充足时使用LRU,否则使用MEMORY(WEAK)通常能获得较好的效果。
<property name="size" value="1000"/>
size必须为整数,代表保存在Cache的中对象的最大数目。因此不要Cache太多的对象,以免内存不足。
分享到:
相关推荐
dao.jar<br>spring-hibernate3.jar<br>spring-ibatis.jar<br>spring-jdbc.jar<br>spring-jdo.jar<br>spring-jpa.jar<br>spring-toplink.jar<br>persistence.jar<br>spring-aop.jar<br>spring-agent.jar<br>spring-...
<select id="getByLike" resultClass="Account" parameterClass="Account" cacheModel="categoryCache"> select ACC_ID as id, ACC_FIRST_NAME as firstName, ACC_LAST_NAME as lastName, ACC_EMAIL as ...
logging.jar<br>log4j-1.2.14.jar<br>spring-dao.jar<br>spring-hibernate3.jar<br>spring-ibatis.jar<br>spring-jdbc.jar<br>spring-jdo.jar<br>spring-jpa.jar<br>spring-toplink.jar<br>persistence.jar<br>...
<spring.version>4.0.2.RELEASE</spring.version> <!-- mybatis 版本号 --> <mybatis.version>3.2.6</mybatis.version> </properties> <dependencies> <!-- Spring 核心库 --> <dependency> <groupId>org....
- **定义Spring的配置参数**:通过`<context-param>`元素来指定Spring的配置文件路径。在本例中,配置文件为`applicationContext.xml`,放置于`/WEB-INF/conf/`目录下。 - **注册Spring的`ContextLoaderServlet`**:...
<spring.version>4.0.2.RELEASE</spring.version> <mybatis.version>3.2.6</mybatis.version> <slf4j.version>1.7.7</slf4j.version> <log4j.version>1.2.17</log4j.version> </properties> <dependencies> <!...
`<url-pattern>/*</url-pattern>`表示该过滤器应用于所有请求路径。 #### 四、Struts配置 ##### 4.1 Struts2过滤器配置 ```xml <filter> <filter-name>struts2</filter-name> <filter-class>org.apache.struts2...
ibatis缓存介绍 - 勇泽 - 博客园ibatis缓存介绍 - 勇泽 - 博客园ibatis缓存介绍 - 勇泽 - 博客园ibatis缓存介绍 - 勇泽 - 博客园
<artifactId>struts2-core</artifactId> <version>2.5.24</version> </dependency> <!-- iBatis --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.5.7</...
### flex-ibatis-spring项目的创建详解 #### 一、项目概述 在当前软件开发领域,结合多种技术栈来构建高效稳定的应用系统已成为一种趋势。本文档将详细介绍如何创建一个基于`flex`、`ibatis`(现已更名为MyBatis)...
apache开源项目源码ibatis-3-core-src-3.0.0.227 ibatis框架java源程序 spring,struts,hibernate,ibatis,框架源码 各种ibatis框架应用源码,你会从中得到意想不到的效果! apache开源组织开发的开源项目源码,其...
<value>classpath:ibatis-Base.xml</value> </property> <property name="dataSource"> <ref bean="dataSource"/> </property> </bean> <!-- 配置sqlMapClientTemplate模板 --> <bean id=...
<bean id="sqlMapClientTemplate" class="org.springframework.orm.ibatis.SqlMapClientTemplate"> <property name="sqlMapClient"> <ref bean="sqlMapClient" /> </property> </bean> <!-- 配置要...
ibatis-3-core-3.0.0.242.jar.zipibatis-3-core-3.0.0.242.jar.zipibatis-3-core-3.0.0.242.jar.zipibatis-3-core-3.0.0.242.jar.zipibatis-3-core-3.0.0.242.jar.zip
<typeAlias alias="user" type="ch10.SpringAndIbatis.Ibatis"/> <resultMap id="ibatisTest" class="user"> <result column="id" property="id" jdbcType="VARCHAR"/> <result column="name" property="name" ...
<result name="success">/success.jsp</result> </action> </package> ``` iBatis作为数据访问层,允许开发者编写SQL语句并映射到Java对象。最小配置需要在`mybatis-config.xml`中设置数据源,并创建对应的Mapper...
return new ResponseEntity<>(patrols, HttpStatus.OK); } // 其他API接口... } ``` 通过上述步骤,我们就成功地创建了一个使用SpringBoot、Mybatis和MySQL的接口实例。用户可以通过`/patrols`接口获取所有巡逻...
><nodes><node id="40" text="咨询" /><node id="20" text="建议" /><node id="10" text="投诉" /><node id="50" text="预约" /><node id="30" text="报障" /><node id="1090464" text="集团自查工单修改" /><node ...