redis?redisTemplate數(shù)據(jù)類型基礎操作
redis基礎概述
一、五大數(shù)據(jù)類型
1、string
- string是redis最基本的類型,你可以理解成與Memcached一模一樣的類型,一個key對應一個value。
- string類型是二進制安全的。意思是redis的string可以包含任何數(shù)據(jù)。比如jpg圖片或者序列化的對象 。
- string類型是Redis最基本的數(shù)據(jù)類型,一個redis中字符串value最多可以是512M
2、hash
- Redis hash 是一個鍵值對集合。
- Redis hash是一個string類型的field和value的映射表,hash特別適合用于存儲對象。
3、list
- Redis 列表是簡單的字符串列表,按照插入順序排序。
- 你可以添加一個元素導列表的頭部(左邊)或者尾部(右邊)。
它的底層實際是個鏈表
4、set
- Redis的Set是string類型的無序集合。
- 它是通過HashTable實現(xiàn)實現(xiàn)的。
5、zset
- Redis zset 和 set 一樣也是string類型元素的集合,且不允許重復的成員。
- 不同的是每個元素都會關聯(lián)一個double類型的分數(shù)。
- redis正是通過分數(shù)來為集合中的成員進行從小到大的排序。zset的成員是唯一的,但分數(shù)(score)卻可以重復。
二、redis 常用操作
1、redis鍵常用
2、常用String
set/get/del/append/strlenIncr/decr/incrby/decrby,一定要是數(shù)字才能進行加減getrange:獲取指定區(qū)間范圍內(nèi)的值,類似between…and的關系
setrange
設置指定區(qū)間范圍內(nèi)的值,格式是setrange key值 具體值setex
:設置帶過期時間的key,動態(tài)設置。setex
鍵 秒值 真實值setnx
:只有在 key 不存在時設置 key 的值。mset
:同時設置一個或多個 key-value 對。getset
:將給定 key 的值設為 value ,并返回 key 的舊值(old value)。
簡單一句話,先get然后立即set
3、常用List
lpush/rpush/lrange
- lpop/rpop彈出值
- 通過索引獲取列表中的元素 lindex key index:lindex list2 2
lrem key 刪N個value:
- 從left往right刪除2個值等于v1的元素,返回的值為實際刪除的數(shù)量
- LREM list3 0 值,表示刪除全部給定的值。零個就是全部值
- ltrim key 開始index 結束index,截取指定范圍的值后再賦值給key
- ltrim:截取指定索引區(qū)間的元素,格式是ltrim list的key 起始索引 結束索引
rpoplpush 源列表 目的列表
- 移除列表的最后一個元素,并將該元素添加到另一個列表并返回
- lset key index value:將值插入某位置
- linsert key before/after 值1 值2
- 在list某個已有值的前后再添加具體值
它是一個字符串鏈表,left、right都可以插入添加;
- 如果鍵不存在,創(chuàng)建新的鏈表;
- 如果鍵已存在,新增內(nèi)容;
- 如果值全移除,對應的鍵也就消失了。
鏈表的操作無論是頭和尾效率都極高,但假如是對中間元素進行操作,效率就很慘淡了。
4、常用Set
- 差集:sdiff
- 交集:sinter
- 并集:sunion
5、常用hash
hset/hget/hmset/hmget/hgetall/hdel
hexists key 在key里面的某個值的key
6、常用zset
9.zrangebyscore key min max limit 0 5分頁
15.zrevrange key
16.zrevrangebyscore key 在set基礎上,加一個score值。
之前set是k1 v1 v2 v3,
現(xiàn)在zset是k1 score1 v1 score2 v2
三、redis 緩存過期策略
lru
(最近最少使用)ttl
(有限時間內(nèi))random
(隨機刪除)
()volatile-lru -> remove the key with an expire set using an LRU algorithm
使用LRU算法移除key,只對設置了過期時間的鍵
()# allkeys-lru -> remove any key according to the LRU algorithm
使用LRU算法移除key
() # volatile-random -> remove a random key with an expire set
在過期集合中移除隨機的key,只對設置了過期時間的鍵
() # allkeys-random -> remove a random key, any key
移除隨機的key
() # volatile-ttl -> remove the key with the nearest expire time (minor TTL)
移除那些TTL值最小的key,即那些最近要過期的key
(永不過期) # noeviction -> don’t expire at all, just return an error on write operations
不進行移除。針對寫操作,只是返回錯誤信息
總結
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Java使用redisson實現(xiàn)分布式鎖的示例詳解
這篇文章主要為大家詳細介紹了在Java項目中使用redisson實現(xiàn)分布式鎖,文中的示例代碼講解詳細,具有一定的學習價值,需要的可以參考一下2023-07-07java 用泛型參數(shù)類型構造數(shù)組詳解及實例
這篇文章主要介紹了java 用泛型參數(shù)類型構造數(shù)組詳解及實例的相關資料,需要的朋友可以參考下2017-02-02java哈希算法HashMap經(jīng)典面試題目匯總解析
這篇文章主要為大家介紹了java哈希算法HashMap的經(jīng)典面試題目匯總及問題解析,幫助大家徹底征服面試官,實現(xiàn)薪資自由,有需要的朋友可以借鑒參考下,希望能夠有所幫助2022-03-03java并發(fā)容器CopyOnWriteArrayList實現(xiàn)原理及源碼分析
這篇文章主要為大家詳細介紹了java并發(fā)容器CopyOnWriteArrayList實現(xiàn)原理及源碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-05-05