java 用redisTemplate 的 Operations存取list集合操作
java redisTemplate 的 Operations存取list集合
一 、存取為list類型
@RestController
@RequestMapping("/test")
@Slf4j
public class TestController {
@Autowired
private RedisTemplate redisTemplate;
@ApiOperation("redis-savelist")
@PostMapping("/redis/save/list")
public void redisSaveList() {
List<Person> list = getPersonList();
//清空
while (redisTemplate.opsForList().size("oowwoo") > 0){
redisTemplate.opsForList().leftPop("oowwoo");
}
//存儲(chǔ)
redisTemplate.opsForList().rightPushAll("oowwoo", list);
//取出
List<Person> oowwoo = redisTemplate.opsForList().range("oowwoo", 0, -1);
log.info(">>>>>>>>>>>>>>>list = {}", oowwoo.toString());
Iterator<Person> it = oowwoo.iterator();
while(it.hasNext()){
Person p = it.next();
log.info("person = {}", p.toString());
}
}
private List<Person> getPersonList() {
Person p1 = new Person();
p1.setId(1L);
p1.setName("張一");
p1.setAge(11);
Person p2 = new Person();
p2.setId(2L);
p2.setName("張二");
p2.setAge(22);
Person p3 = new Person();
p3.setId(3L);
p3.setName("張三");
p3.setAge(33);
List<Person> list = new ArrayList<>();
list.add(p1);
list.add(p2);
list.add(p3);
return list;
}
}
二 、將list轉(zhuǎn)為json對象存取
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
@Autowired
private StringRedisTemplate stringRedisTemplate;
//存
List<Long> businessIdList = eeFreecarriageShopService.selectBusinessIdInPromotion();
stringRedisTemplate.opsForValue().set(RedisConstants.FREECARRIAGE_BUSINESSIDLIST, JSON.toJSON(businessIdList).toString());
//取
String businessJsonArray = stringRedisTemplate.opsForValue().get(RedisConstants.FREECARRIAGE_BUSINESSIDLIST);
List<Long> businessIdList = JSONObject.parseArray(businessJsonArray, Long.class);
redis在java中的使用,基本存取操作(RedisTemplate)
redis
REmote DIctionary Server(Redis) 是一個(gè)由 Salvatore Sanfilippo 寫的 key-value 存儲(chǔ)系統(tǒng),是跨平臺的非關(guān)系型數(shù)據(jù)庫。
Redis 是一個(gè)開源的使用 ANSI C 語言編寫、遵守 BSD 協(xié)議、支持網(wǎng)絡(luò)、可基于內(nèi)存、分布式、可選持久性的鍵值對(Key-Value)存儲(chǔ)數(shù)據(jù)庫,并提供多種語言的 API。
Redis 通常被稱為數(shù)據(jù)結(jié)構(gòu)服務(wù)器,因?yàn)橹担╲alue)可以是字符串(String)、哈希(Hash)、列表(list)、集合(sets)和有序集合(sorted sets)等類型。
RedisTemplate
spring 封裝了 RedisTemplate 對象來進(jìn)行對redis的各種操作,它支持所有的 redis 原生的 api。
StringRedisTemplate與RedisTemplate
兩者的關(guān)系是StringRedisTemplate繼承RedisTemplate。
兩者的數(shù)據(jù)是不共通的;也就是說StringRedisTemplate只能管理StringRedisTemplate里面的數(shù)據(jù),RedisTemplate只能管理RedisTemplate中的數(shù)據(jù)。
SDR默認(rèn)采用的序列化策略有兩種,一種是String的序列化策略,一種是JDK的序列化策略。
StringRedisTemplate默認(rèn)采用的是String的序列化策略,保存的key和value都是采用此策略序列化保存的。
RedisTemplate默認(rèn)采用的是JDK的序列化策略,保存的key和value都是采用此策略序列化保存的。
set void set(K key, V value);
使用:redisTemplate.opsForValue().set("name","tom");
結(jié)果:redisTemplate.opsForValue().get("name") 輸出結(jié)果為tom
set void set(K key, V value, long timeout, TimeUnit unit);
使用:redisTemplate.opsForValue().set("name","tom",10, TimeUnit.SECONDS);
結(jié)果:redisTemplate.opsForValue().get("name")由于設(shè)置的是10秒失效,十秒之內(nèi)查詢有結(jié)果,十秒之后返回為null
這里只討論對string數(shù)據(jù)的使用,附上一個(gè)小demo
首先需要導(dǎo)入相關(guān)的依賴
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
序列化,序列化是為了方便數(shù)據(jù)傳輸
這里提供兩種序列化封裝操作:
第一種
@Service
public class TokenServiceTask {
public static final String ONLINE_OPERRATOR = "";
/**
* redis序列化存儲(chǔ)
*
* @param redisTemplate
*/
@SuppressWarnings({"rawtypes", "unchecked"})
@Autowired(required = false)
public void setRedisTemplate(RedisTemplate redisTemplate) {
RedisSerializer stringSerializer = new StringRedisSerializer();
redisTemplate.setKeySerializer(stringSerializer);
redisTemplate.setValueSerializer(stringSerializer);
redisTemplate.setHashKeySerializer(stringSerializer);
redisTemplate.setHashValueSerializer(stringSerializer);
this.redisTemplate = redisTemplate;
}
@Resource
private RedisTemplate<String, String> redisTemplate;
public void setToken(String key, String token) {
ValueOperations<String, String> value = redisTemplate.opsForValue();
value.set(ONLINE_OPERRATOR + key, token);
}
public void setTokenWithTime(String key, String token, long number, TimeUnit timeUnit) {
ValueOperations<String, String> value = redisTemplate.opsForValue();
value.set(ONLINE_OPERRATOR + key, token, number, timeUnit);
}
public void freshTime(String key) {
redisTemplate.expire(key, 1800, TimeUnit.SECONDS);
}
public String getToken(String key) {
return redisTemplate.boundValueOps(key).get();
}
}
第二種
@Configuration
@EnableCaching //啟用緩存,這個(gè)注解很重要;
public class RedisCacheConfig extends CachingConfigurerSupport {
/**
* 緩存管理器.
* @param redisTemplate
* @return
*/
@Bean
public CacheManager cacheManager(RedisTemplate<?,?> redisTemplate) {
CacheManager cacheManager = new RedisCacheManager(redisTemplate);
return cacheManager;
}
/**
* redis模板操作類,類似于jdbcTemplate的一個(gè)類;
*
* 雖然CacheManager也能獲取到Cache對象,但是操作起來沒有那么靈活;
*
* 這里在擴(kuò)展下:RedisTemplate這個(gè)類不見得很好操作,我們可以在進(jìn)行擴(kuò)展一個(gè)我們
*
* 自己的緩存類,比如:RedisStorage類;
*
* @param factory : 通過Spring進(jìn)行注入,參數(shù)在application.properties進(jìn)行配置;
* @return
*/
@Bean
public RedisTemplate<String, String> redisTemplate(RedisConnectionFactory factory) {
RedisTemplate<String,String> redisTemplate = new RedisTemplate<String, String>();
redisTemplate.setConnectionFactory(factory);
//key序列化方式;(不然會(huì)出現(xiàn)亂碼;),但是如果方法上有Long等非String類型的話,會(huì)報(bào)類型轉(zhuǎn)換錯(cuò)誤;
//所以在沒有自己定義key生成策略的時(shí)候,以下這個(gè)代碼建議不要這么寫,可以不配置或者自己實(shí)現(xiàn)ObjectRedisSerializer
//或者JdkSerializationRedisSerializer序列化方式;
RedisSerializer<String> redisSerializer = new StringRedisSerializer();//Long類型不可以會(huì)出現(xiàn)異常信息;
redisTemplate.setKeySerializer(redisSerializer);
redisTemplate.setHashKeySerializer(redisSerializer);
return redisTemplate;
}
}
接下來上操作
public void test01() {
redisTemplate.opsForValue().set("chenlianghongtest","chenlianghong",30, TimeUnit.SECONDS);
String test = redisTemplate.opsForValue().get("chenlianghongtest");
System.out.println(test);
logger.info("牛啊牛啊");
}
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java實(shí)現(xiàn)兩人五子棋游戲(五) 判斷是否有一方勝出
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)兩人五子棋游戲,判斷是否有一方勝出,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-03-03
Java?SpringBoot項(xiàng)目如何優(yōu)雅的實(shí)現(xiàn)操作日志記錄
這篇文章主要介紹了Java?SpringBoot項(xiàng)目如何優(yōu)雅的實(shí)現(xiàn)操作日志記錄,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的朋友可以參考一下2022-08-08
Eclipse可視化插件WindowBuilder的安裝方法
這篇文章主要介紹了Eclipse可視化插件WindowBuilder的安裝方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06
spring AOP的After增強(qiáng)實(shí)現(xiàn)方法實(shí)例分析
這篇文章主要介紹了spring AOP的After增強(qiáng)實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了spring面向切面AOP的After增強(qiáng)實(shí)現(xiàn)步驟與相關(guān)操作技巧,需要的朋友可以參考下2020-01-01
Java網(wǎng)絡(luò)通信中URL與HTTP編程技術(shù)詳解
要想實(shí)現(xiàn)網(wǎng)絡(luò)編程,除了可以使用Socket之外,我們還可以利用URL編程或HTTP編程技術(shù),所以今天這篇文章,就給大家介紹一下URL編程和HTTP編程技術(shù),看看這兩種技術(shù)有什么特點(diǎn),文中有詳細(xì)的代碼講解,需要的朋友可以參考下2023-11-11
java報(bào)錯(cuò):“錯(cuò)誤:編碼GBK?的不可映射字符”解決辦法
當(dāng)Java源代碼中包含中文字符時(shí),我們在用javac編譯時(shí)會(huì)出現(xiàn)“錯(cuò)誤:編碼GBK的不可映射字符”,這篇文章主要給大家介紹了關(guān)于java報(bào)錯(cuò):“錯(cuò)誤:編碼GBK?的不可映射字符”的解決辦法,需要的朋友可以參考下2024-08-08

