zoukankan      html  css  js  c++  java
  • spring boot mybatis redis缓存

    使用场景: 集群环境,不能使用JVM缓存,改用redis缓存

    pom

          <dependency>
    			<groupId>org.springframework.boot</groupId>
    			<artifactId>spring-boot-starter-data-redis</artifactId>
    		</dependency>
    		<dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-cache</artifactId>
            </dependency>
    

    application.properties

    # redis连接配置
    spring.redis.host= localhost
    spring.redis.port= 6379
    spring.redis.password=
    spring.redis.timeout=43200
    
    # cache
    spring.cache.type=redis
    

    dao

    @CacheConfig(cacheNames="dictDtlCache")
    class DictDao
    {
    		@Cacheable(key = "T(String).valueOf(#strSn) + ':' +T(String).valueOf(#key)")
    	public DictionaryDtl findOneByDictSnAndKey(String strSn, String key)
    	{
    		Map<String, Object> map = new HashMap<>();
    		map.put("strSn", strSn);
    		map.put("key", key);
    		return sqlsession.selectOne("DictionaryDtlDao.findOneByDictSnAndKey", map);
    	}
    
    	/**
    	 * @description 默认一级字典strSn存在,二级字典可以不存在
    	 * @author zhuxiang
    	 * @date 13:46 2020/7/9
    	 * @param: strSn
    	 * @param: key
    	 * @param: value
    	 * @return int
    	 **/
    	@CachePut(key = "T(String).valueOf(#strSn) + ':' +T(String).valueOf(#key)")
    	public DictionaryDtl setValueByDictSnAndKey(String strSn, String key, String value)
    	{
    		Map<String, Object> map = new HashMap<>();
    		map.put("strSn", strSn);
    		map.put("key", key);
    		map.put("value", value);
    		if (findOneByDictSnAndKey(strSn, key) == null)
    		{
    			map.put("id", UUIDUtil.getUUID());
    			map.put("username", "admin");
    			map.put("sysdate", new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));
    			sqlsession.insert("DictionaryDtlDao.insertValueByDictSnAndKey", map);
    		}
    		sqlsession.update("DictionaryDtlDao.updateValueByDictSnAndKey", map);
    		return findOneByDictSnAndKey(strSn, key);
    	}
    }
  • 相关阅读:
    Navicat for MySQL远程连接的时候报错mysql 1130的解决方法
    阿里云主机 CentOS6.5 安装Mysql php Apache
    MAC下使用feddler进行抓包
    javascript钩子之Backbone里的实现
    SASS编译
    动态代理模式和AOP探究
    二分查找算法
    MyBatis在非Spring环境下第三方DataSource设置-Druid篇
    写字节流转换String 代码示例
    SpringAOP代理报错问题
  • 原文地址:https://www.cnblogs.com/zhuxiang1633/p/13276017.html
Copyright © 2011-2022 走看看