spring boot整合redis實(shí)現(xiàn)RedisTemplate三分鐘快速入門
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId></dependency>RedisTemplate五種數(shù)據(jù)結(jié)構(gòu)的操作 redisTemplate.opsForValue(); //操作字符串 redisTemplate.opsForHash(); //操作hash redisTemplate.opsForList(); //操作list redisTemplate.opsForSet(); //操作set redisTemplate.opsForZSet(); //操作有序zsetRedisTemplate方法講解
判斷key是否存在
/** * 判斷key是否存在 */ @GetMapping('haskey') public boolean hasKey(String key) { return redisTemplate.hasKey(key); }
獲取指定的key的失效時(shí)間
/** * 指定key的失效時(shí)間 */ @GetMapping('expire') public void expire(String key, long time) { //參數(shù)一:key //參數(shù)二:睡眠時(shí)間 //參數(shù)三:睡眠時(shí)間單位 TimeUnit.DAYS 天 TimeUnit.HOURS 小時(shí) 。。。 redisTemplate.expire(key, time, TimeUnit.MINUTES); }
根據(jù)key獲取過期時(shí)間
/** * 根據(jù)key獲取過期時(shí)間 */ @GetMapping('getexpire') public long getExpire(String key) { Long expire = redisTemplate.getExpire(key); return expire; }
根據(jù)key刪除reids中緩存數(shù)據(jù)
/** * 根據(jù)key刪除reids中緩存數(shù)據(jù) */ @GetMapping('delredisbykey') public void delete(String key) { redisTemplate.delete(key); }
保存和讀取String
/** * 保存和讀取String */ @GetMapping('stringredisdemo') public String stringredisdemo() { //設(shè)置過期時(shí)間為1分鐘 redisTemplate.opsForValue().set('key1', 'value1', 1, TimeUnit.MINUTES); redisTemplate.opsForValue().set('key2', 'value2'); redisTemplate.opsForValue().set('key3', 'value3'); //讀取redis數(shù)據(jù) String result1 = redisTemplate.opsForValue().get('key1').toString(); String result2 = redisTemplate.opsForValue().get('key2').toString(); String result3 = redisTemplate.opsForValue().get('key3').toString(); System.out.println('緩存結(jié)果為:result:' + result1 + ' ' + result2 + ' ' + result3); return '緩存結(jié)果為:result:' + result1 + ' ' + result2 + ' ' + result3; }
保存和讀取list
/** * 保存和讀取list */ @GetMapping('listredisdemo') public String listredisdemo() { List<String> list1 = new ArrayList<>(); list1.add('a1'); list1.add('a2'); list1.add('a3'); List<String> list2 = new ArrayList<>(); list2.add('b1'); list2.add('b2'); list2.add('b3'); redisTemplate.opsForList().leftPush('listkey1', list1); redisTemplate.opsForList().rightPush('listkey2', list2); List<String> resultList1 = (List<String>) redisTemplate.opsForList().leftPop('listkey1'); List<String> resultList2 = (List<String>) redisTemplate.opsForList().rightPop('listkey2'); System.out.println('resultList1:' + resultList1); System.out.println('resultList2:' + resultList2); return '成功'; }
Hash結(jié)構(gòu),保存和讀取map
/** * Hash結(jié)構(gòu),保存和讀取map */ @GetMapping('mapredisdemo') public String mapredisdemo() { Map<String, String> map = new HashMap<>(); map.put('key1', 'value1'); map.put('key2', 'value2'); map.put('key3', 'value3'); map.put('key4', 'value4'); map.put('key5', 'value5'); redisTemplate.opsForHash().putAll('map1', map); Map<String, String> resultMap = redisTemplate.opsForHash().entries('map1'); List<String> reslutMapList = redisTemplate.opsForHash().values('map1'); Set<String> resultMapSet = redisTemplate.opsForHash().keys('map1'); String value = (String) redisTemplate.opsForHash().get('map1', 'key1'); System.out.println('value:' + value); System.out.println('resultMapSet:' + resultMapSet); System.out.println('resultMap:' + resultMap); System.out.println('resulreslutMapListtMap:' + reslutMapList); return '成功'; }
保存和讀取Set
/** * 保存和讀取Set */ @GetMapping('setredisdemo') public String getredisdemo() { SetOperations<String, String> set = redisTemplate.opsForSet(); set.add('key1', 'value1'); set.add('key1', 'value2'); set.add('key1', 'value3'); Set<String> resultSet = redisTemplate.opsForSet().members('key1'); System.out.println('resultSet:' + resultSet); return 'resultSet:' + resultSet; }
保存和讀取zset
/** * 保存和讀取zset */ @GetMapping('zsetredisdemo') public String zsetredisdemo() { ZSetOperations.TypedTuple<Object> objectTypedTuple1 = new DefaultTypedTuple<>('zset-5', 9.6); ZSetOperations.TypedTuple<Object> objectTypedTuple2 = new DefaultTypedTuple<>('zset-6', 9.9); Set<ZSetOperations.TypedTuple<Object>> tuples = new HashSet<>(); tuples.add(objectTypedTuple1); tuples.add(objectTypedTuple2); System.out.println(redisTemplate.opsForZSet().add('zset1', tuples)); System.out.println(redisTemplate.opsForZSet().range('zset1', 0, -1)); return '成功'; }完整示例代碼
import org.springframework.beans.factory.annotation.Autowired;import org.springframework.data.redis.core.DefaultTypedTuple;import org.springframework.data.redis.core.RedisTemplate;import org.springframework.data.redis.core.SetOperations;import org.springframework.data.redis.core.ZSetOperations;import org.springframework.web.bind.annotation.GetMapping;import org.springframework.web.bind.annotation.RestController;import java.util.*;import java.util.concurrent.TimeUnit;@RestControllerpublic class ReidsDemo { @Autowired RedisTemplate redisTemplate; /** * 指定key的失效時(shí)間 */ @GetMapping('expire') public void expire(String key, long time) { //參數(shù)一:key //參數(shù)二:睡眠時(shí)間 //參數(shù)三:睡眠時(shí)間單位 TimeUnit.DAYS 天 TimeUnit.HOURS 小時(shí) 。。。 redisTemplate.expire(key, time, TimeUnit.MINUTES); } /** * 根據(jù)key獲取過期時(shí)間 */ @GetMapping('getexpire') public long getExpire(String key) { Long expire = redisTemplate.getExpire(key); return expire; } /** * 判斷key是否存在 */ @GetMapping('haskey') public boolean hasKey(String key) { return redisTemplate.hasKey(key); } /** * 根據(jù)key刪除reids中緩存數(shù)據(jù) */ @GetMapping('delredisbykey') public void delete(String key) { redisTemplate.delete(key); } /** * 保存和讀取String */ @GetMapping('stringredisdemo') public String stringredisdemo() { //設(shè)置過期時(shí)間為1分鐘 redisTemplate.opsForValue().set('key1', 'value1', 1, TimeUnit.MINUTES); redisTemplate.opsForValue().set('key2', 'value2'); redisTemplate.opsForValue().set('key3', 'value3'); //讀取redis數(shù)據(jù) String result1 = redisTemplate.opsForValue().get('key1').toString(); String result2 = redisTemplate.opsForValue().get('key2').toString(); String result3 = redisTemplate.opsForValue().get('key3').toString(); System.out.println('緩存結(jié)果為:result:' + result1 + ' ' + result2 + ' ' + result3); return '緩存結(jié)果為:result:' + result1 + ' ' + result2 + ' ' + result3; } /** * 保存和讀取list */ @GetMapping('listredisdemo') public String listredisdemo() { List<String> list1 = new ArrayList<>(); list1.add('a1'); list1.add('a2'); list1.add('a3'); List<String> list2 = new ArrayList<>(); list2.add('b1'); list2.add('b2'); list2.add('b3'); redisTemplate.opsForList().leftPush('listkey1', list1); redisTemplate.opsForList().rightPush('listkey2', list2); List<String> resultList1 = (List<String>) redisTemplate.opsForList().leftPop('listkey1'); List<String> resultList2 = (List<String>) redisTemplate.opsForList().rightPop('listkey2'); System.out.println('resultList1:' + resultList1); System.out.println('resultList2:' + resultList2); return '成功'; } /** * Hash結(jié)構(gòu),保存和讀取map */ @GetMapping('mapredisdemo') public String mapredisdemo() { Map<String, String> map = new HashMap<>(); map.put('key1', 'value1'); map.put('key2', 'value2'); map.put('key3', 'value3'); redisTemplate.opsForHash().putAll('map1', map); Map<String, String> resultMap = redisTemplate.opsForHash().entries('map1'); List<String> reslutMapList = redisTemplate.opsForHash().values('map1'); Set<String> resultMapSet = redisTemplate.opsForHash().keys('map1'); String value = (String) redisTemplate.opsForHash().get('map1', 'key1'); System.out.println('value:' + value); System.out.println('resultMapSet:' + resultMapSet); System.out.println('resultMap:' + resultMap); System.out.println('resulreslutMapListtMap:' + reslutMapList); return '成功'; } /** * 保存和讀取Set */ @GetMapping('setredisdemo') public String getredisdemo() { SetOperations<String, String> set = redisTemplate.opsForSet(); set.add('key1', 'value1'); set.add('key1', 'value2'); set.add('key1', 'value3'); Set<String> resultSet = redisTemplate.opsForSet().members('key1'); System.out.println('resultSet:' + resultSet); return 'resultSet:' + resultSet; } /** * 保存和讀取zset */ @GetMapping('zsetredisdemo') public String zsetredisdemo() { ZSetOperations.TypedTuple<Object> objectTypedTuple1 = new DefaultTypedTuple<>('zset-5', 9.6); ZSetOperations.TypedTuple<Object> objectTypedTuple2 = new DefaultTypedTuple<>('zset-6', 9.9); Set<ZSetOperations.TypedTuple<Object>> tuples = new HashSet<>(); tuples.add(objectTypedTuple1); tuples.add(objectTypedTuple2); System.out.println(redisTemplate.opsForZSet().add('zset1', tuples)); System.out.println(redisTemplate.opsForZSet().range('zset1', 0, -1)); return '成功'; }}序列化
直接粘貼在項(xiàng)目中即可
import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.data.redis.connection.RedisConnectionFactory;import org.springframework.data.redis.core.RedisTemplate;import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer;import org.springframework.data.redis.serializer.RedisSerializer;import org.springframework.data.redis.serializer.StringRedisSerializer;/**序列化 */@Configurationpublic class MyRedisConfig { @Bean(name = 'redisTemplate') public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory){ RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>(); //參照StringRedisTemplate內(nèi)部實(shí)現(xiàn)指定序列化器 redisTemplate.setConnectionFactory(redisConnectionFactory); redisTemplate.setKeySerializer(keySerializer()); redisTemplate.setHashKeySerializer(keySerializer()); redisTemplate.setValueSerializer(valueSerializer()); redisTemplate.setHashValueSerializer(valueSerializer()); return redisTemplate; } private RedisSerializer<String> keySerializer(){ return new StringRedisSerializer(); } //使用Jackson序列化器 private RedisSerializer<Object> valueSerializer(){ return new GenericJackson2JsonRedisSerializer(); } }
到此這篇關(guān)于spring boot整合redis實(shí)現(xiàn)RedisTemplate三分鐘快速入門的文章就介紹到這了,更多相關(guān)springboot RedisTemplate入門內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. python 批量下載bilibili視頻的gui程序2. ThinkPHP5 通過ajax插入圖片并實(shí)時(shí)顯示(完整代碼)3. WML語(yǔ)言的基本情況4. React優(yōu)雅的封裝SvgIcon組件示例5. ajax post下載flask文件流以及中文文件名問題6. 使用css實(shí)現(xiàn)全兼容tooltip提示框7. ASP中解決“對(duì)象關(guān)閉時(shí),不允許操作。”的詭異問題……8. AJAX實(shí)現(xiàn)數(shù)據(jù)的增刪改查操作詳解【java后臺(tái)】9. el-table表格動(dòng)態(tài)合并相同數(shù)據(jù)單元格(可指定列+自定義合并)10. 利用CSS3新特性創(chuàng)建透明邊框三角
