mybatis:一級キャッシュAnd二級キャッシュ

23824 ワード

一級キャッシュは、hibernateと同様にsessionキャッシュであり、つまりこのキャッシュの適用範囲は同一のSql Sessionであり、二級キャッシュ、mybatis自身もキャッシュを実現していますが、mybatisのキャッシュが実現しています.ここではEhCacheとMyBatisの統合を紹介します.
デフォルトのMybatisキャッシュ設定は、mapper.xmlにラベルを設定するだけです.
namespace="com.xbz.user.mapper.UserMapper">
    "org.mybatis.caches.ehcache.EhcacheCache">
    <select id="selectById" parameterType="java.lang.Long" resultType="com.xbz.user.entity.User">
        SELECT * FROM users WHERE id = #{id}
    select>
 
testクラス
    @Test
    public void testTwoLevelCache(){
        User user1 = userMapper.selectById(1L);
        System.out.println("--------------------------------------------------------------------");
        User user2 = userMapper.selectById(1L);
        System.out.println(user1==user2);
    }
テストの結果、以下のログから分かるように、myabitisは確かに二級キャッシュを使っています.二回データベースを調べていませんが、二つのuserは同じではありません.
理由:まずmybatisのキャッシュの実体類は、Serializableインターフェースを実現しなければならない.また、データを逐次的に二級キャッシュを検索する時に、順序を逆にして並べ替えてもいいと思います.
2016-09-26 20:29:39,464 org.mybatis.spring.transaction.SpringManagedTransaction.openConnection JDBC Connection [com.mchange.v2.c3p0.impl.NewProxyConnection@31148fb3] will be managed by Spring
2016-09-26 20:29:39,474 com.xbz.user.mapper.UserMapper.selectById.debug ==>  Preparing: SELECT * FROM users WHERE id = ? 
2016-09-26 20:29:39,511 com.xbz.user.mapper.UserMapper.selectById.debug ==> Parameters: 1(Long)
2016-09-26 20:29:39,542 com.xbz.user.mapper.UserMapper.selectById.debug <==      Total: 1
2016-09-26 20:29:39,548 org.mybatis.spring.SqlSessionUtils.closeSqlSession Releasing transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@46603295]
2016-09-26 20:29:39,549 org.mybatis.spring.SqlSessionUtils.beforeCompletion Transaction synchronization deregistering SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@46603295]
2016-09-26 20:29:39,549 org.mybatis.spring.SqlSessionUtils.beforeCompletion Transaction synchronization closing SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@46603295]
--------------------------------------------------------------------
2016-09-26 20:29:39,557 org.mybatis.spring.SqlSessionUtils.getSqlSession Creating a new SqlSession
2016-09-26 20:29:39,557 org.mybatis.spring.SqlSessionUtils.registerSessionHolder Registering transaction synchronization for SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@7d230d96]
2016-09-26 20:29:39,577 com.xbz.user.mapper.UserMapper.getObject Cache Hit Ratio [com.xbz.user.mapper.UserMapper]: 0.5
2016-09-26 20:29:39,578 org.mybatis.spring.SqlSessionUtils.closeSqlSession Releasing transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@7d230d96]
2016-09-26 20:29:39,578 org.mybatis.spring.SqlSessionUtils.beforeCompletion Transaction synchronization deregistering SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@7d230d96]
2016-09-26 20:29:39,578 org.mybatis.spring.SqlSessionUtils.beforeCompletion Transaction synchronization closing SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@7d230d96]
false
EhCacheこそが私たちのポイントです.
  • EhCache.jar
  • を導入する.
  • 導入mbtatis-ehcache.jar
  • org.mybatis.caches.ehcache.Ehcache Cache maven方式:
  • <dependency>
        <groupId>net.sf.ehcachegroupId>
        <artifactId>ehcacheartifactId>
        <version>2.10.2version>
    dependency>
    <dependency>
        <groupId>org.mybatisgroupId>
        <artifactId>mybatis-ehcacheartifactId>
        <version>1.0.0version>
    dependency>
    そして前のCacheラベルを再配置します.
    <cache type="org.mybatis.caches.ehcache.EhcacheCache"></cache>
    またテストしてみます.(相変わらず上のテスト方法です.)はははは、今回は満足しましたよね.確かに得るのは同じ対象です.
    2016-09-26 20:40:13,334 org.mybatis.spring.transaction.SpringManagedTransaction.openConnection JDBC Connection [com.mchange.v2.c3p0.impl.NewProxyConnection@20962ef0] will be managed by Spring
    2016-09-26 20:40:13,344 com.xbz.user.mapper.UserMapper.selectById.debug ==>  Preparing: SELECT * FROM users WHERE id = ? 
    2016-09-26 20:40:13,380 com.xbz.user.mapper.UserMapper.selectById.debug ==> Parameters: 1(Long)
    2016-09-26 20:40:13,403 com.xbz.user.mapper.UserMapper.selectById.debug <==      Total: 1
    2016-09-26 20:40:13,409 org.mybatis.spring.SqlSessionUtils.closeSqlSession Releasing transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@504148d4]
    2016-09-26 20:40:13,409 org.mybatis.spring.SqlSessionUtils.beforeCompletion Transaction synchronization deregistering SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@504148d4]
    2016-09-26 20:40:13,410 org.mybatis.spring.SqlSessionUtils.beforeCompletion Transaction synchronization closing SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@504148d4]
    2016-09-26 20:40:13,412 net.sf.ehcache.store.disk.Segment.put put added 0 on heap
    --------------------------------------------------------------------
    2016-09-26 20:40:13,415 org.mybatis.spring.SqlSessionUtils.getSqlSession Creating a new SqlSession
    2016-09-26 20:40:13,415 org.mybatis.spring.SqlSessionUtils.registerSessionHolder Registering transaction synchronization for SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@249c5c4d]
    2016-09-26 20:40:13,415 com.xbz.user.mapper.UserMapper.getObject Cache Hit Ratio [com.xbz.user.mapper.UserMapper]: 0.5
    2016-09-26 20:40:13,415 org.mybatis.spring.SqlSessionUtils.closeSqlSession Releasing transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@249c5c4d]
    2016-09-26 20:40:13,416 org.mybatis.spring.SqlSessionUtils.beforeCompletion Transaction synchronization deregistering SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@249c5c4d]
    2016-09-26 20:40:13,416 org.mybatis.spring.SqlSessionUtils.beforeCompletion Transaction synchronization closing SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@249c5c4d]
    true