1. 程式人生 > 資料庫 >redis中資料型別命令整理

redis中資料型別命令整理

redis是鍵值對的資料庫,有5中主要資料型別:

字串型別(string),雜湊型別(hash),列表型別(list),集合型別(set),有序集合型別(zset)

幾個基本的命令:

函式 說明
keys * 獲得當前資料庫的所有鍵

exists key [key ...] 判斷鍵是否存在,返回個數,如果key有一樣的也是疊加數
del key [key ...] 刪除鍵,返回刪除的個數

type key 獲取減值的資料型別(string,hash,list,set,zset)
flushall 清空所有資料庫
config [get、set] redis配置

-inf 負無窮

+inf正無窮

一:字串型別(string)

字串型別是Redis的最基本型別,它可以儲存任何形式的字串。其它的四種類型都是字串型別的不同形式。

函式 語法
最基本的命令:GET、SET GET key,SET key value value如果有空格需要雙引號以示區分
整數遞增:INCR INCR key 預設值為0,所以首先執行命令得到 1 ,不是整型提示錯誤
增加指定的整數:INCRBY INCRBY key increment
整數遞減:DECR DECR key 預設值為0,所以首先執行命令得到 -1,不是整型提示錯誤
減少指定的整數:DECRBY DECRBY key increment
增加指定浮點數:INCRBYFLOAT INCRBYFLOAT key increment 與INCR命令類似,只不過可以遞增一個雙精度浮點數
向尾部追加值:APPEND APPEND key value redis客戶端並不是輸出追加後的字串,而是輸出字串總長度
獲取字串長度:STRLEN STRLEN key 如果鍵不存在返回0,注意如果有中文時,一箇中文長度是3,redis是使用UTF-8編碼中文的
獲取多個鍵值:MGET MGET key [key ...] 例如:MGET key1 key2
設定多個鍵值:MSET MSET key value [key value ...] 例如:MSET key1 1 key2 "hello redis"
二進位制指定位置值:GETBIT

GETBIT key offset 例如:GETBIT key1 2 ,key1為hello 返回 1,返回的值只有0或1,當key不存在或超出實際長度時為0

設定二進位制位置值:SETBIT SETBIT key offset value ,返回該位置的舊值
二進位制是1的個數:BITCOUNT BITCOUNT key [start end] ,start 、end為開始和結束位元組
位運算:BITOP BITOP operation destkey key [key ...] ,operation支援AND、OR、XOR、NOT
偏移:BITPOS BITPOS key bit [start] [end]

二:雜湊型別(hash)

函式 語法
設定單個:HSET HSET key field value,不存在時返回1,存在時返回0,沒有更新和插入之分
設定多個:HMSET HMSET key field value [field value ...]
讀取單個:HGET HGET key field,不存在是返回nil
讀取多個:HMGET HMGET key field [field ...]
讀取全部:HGETALL HGETALL key,返回時欄位和欄位值的列表
判斷欄位是否存在:HEXISTS HEXISTS key field,存在返回1 ,不存在返回0
欄位不存在時賦值:HSETNX HSETNX key field value,與hset命令不同,hsetnx是鍵不存在時設定值
增加數字:HINCRBY HINCRBY key field increment ,返回增加後的數,不是整數時會提示錯誤
刪除欄位:HDEL HDEL key field [field ...] ,返回被刪除欄位的個數
只獲取欄位名:HKEYS HKEYS key ,返回鍵的所有欄位名
只獲取欄位值:HVALS HVALS key ,返回鍵的所有欄位值
欄位數量:HLEN HLEN key ,返回欄位總數

三:列表型別(list)

內部使用雙向連結串列實現,所以獲取越接近兩端的元素速度越快,但通過索引訪問時會比較慢

函式 語法
新增左邊元素:LPUSH LPUSH key value [value ...] ,返回新增後的列表元素的總個數
新增右邊元素:RPUSH RPUSH key value [value ...] ,返回新增後的列表元素的總個數
移除左邊第一個元素:LPOP LPOP key ,返回被移除的元素值
移除右邊第一個元素:RPOP RPOP key ,返回被移除的元素值
列表元素個數:LLEN LLEN key, 不存在時返回0,redis是直接讀取現成的值,並不是統計個數
獲取列表片段:LRANGE

LRANGE key start stop,如果start比stop靠後時返回空列表,0 -1 返回整個列表正數時:start 開始索引值,stop結束索引值(索引從0開始)負數時:例如 lrange num -2 -1,-2表示最右邊第二個,-1表示最右邊第一個,

刪除指定值:LREM

LREM key count value,返回被刪除的個數

count>0,從左邊開始刪除前count個值為value的元素

count<0,從右邊開始刪除前|count|個值為value的元素

count=0,刪除所有值為value的元素

索引元素值:LINDEX LINDEX key index ,返回索引的元素值,-1表示從最右邊的第一位
設定元素值:LSET LSET key index value
保留列表片段:LTRIM LTRIM key start stop,start、top 參考lrange命令
一個列表轉移另一個列表:RPOPLPUSH

RPOPLPUSH source desctination ,從source列表轉移到desctination列表,該命令分兩步看,首先source列表RPOP右移除,再desctination列表LPUSH

四:集合型別(set)

集合型別值具有唯一性,常用操作是向集合新增、刪除、判斷某個值是否存在,集合內部是使用值為空的散列表實現的。

函式 語法
新增元素:SADD

SADD key member [member ...] ,向一個集合新增一個或多個元素,因為集合的唯一性,所以新增相同值時會被忽略。返回成功新增元素的數量。

刪除元素:SREM SREM key member [member ...] 刪除集合中一個或多個元素,返回成功刪除的個數。
獲取全部元素:SMEMBERS SMEMBERS key ,返回集合全部元素
值是否存在:SISMEMBER
SISMEMBER key member ,如果存在返回1,不存在返回0
差運算:SDIFF SDIFF key [key ...] ,例如:集合A和集合B,差集表示A-B,在A裡有的元素B裡沒有,返回差集合;多個集合(A-B)-C
交運算:SINTER SINTER key [key ...],返回交集集合,每個集合都有的元素
並運算:SUNION  SUNION key [key ...],返回並集集合,所有集合的元素
集合元素個數:SCARD SCARD key ,返回集合元素個數
集合運算後儲存結果

SDIFFSTROE destination key [key ...] ,差運算並存儲到destination新集合中SINTERSTROE destination key [key ...],交運算並存儲到destination新集合中SUNIONSTROE destination key [key ...],並運算並存儲到destination新集合中

隨機獲取元素:SRANDMEMGER

SRANDMEMBER key [count],根據count不同有不同結果,count大於元素總數時返回全部元素count>0 ,返回集合中count不重複的元素count<0,返回集合中count的絕對值個元素,但元素可能會重複

彈出元素:SPOP SPOP key [count] ,因為集合是無序的,所以spop會隨機彈出一個元素

五:有序集合型別 zset(sorted set:有序集合)

Redis zset 和 set 一樣也是string型別元素的集合,且不允許重複的成員。

不同的是每個元素都會關聯一個double型別的分數。

redis正是通過分數來為集合中的成員進行從小到大的排序。zset的成員是唯一的,但分數(score)卻可以重複。

函式 語法
新增集合元素:ZADD ZADD key [NX|XX] [CH] [INCR] score member [score member ...],不存在新增,存在更新。
獲取元素分數:ZSCORE ZSCORE key member ,返回元素成員的score 分數
元素小到大:ZRANGE

ZRANGE key start top [WITHSCORES] ,參考LRANGE ,加上withscores 返回帶元素,即元素,分數當分數一樣時,按元素排序

元素大到小:ZREVRANGE ZREVRANGE key start [WITHSCORES] ,與zrange區別在於zrevrange是從大到小排序
指定分數範圍元素:ZRANGEBYSCORE

ZRANGEBYSCORE key min max [WITHSCORE] [LIMIT offest count]返回從小到大的在min和max之間的元素,( 符號表示不包含,例如:80-100,(80 100,withscore返回帶分數limit offest count 向左偏移offest個元素,並獲取前count個元素

指定分數範圍元素:ZREVRANGESCORE

ZREVRANGEBYSCORE key max min [WITHSCORE] [LIMIT offest count]與zrangebyscore類似,只不過該命令是從大到小排序的。

增加分數:ZINCRBY ZINCRBY key increment member ,注意是增加分數,返回增加後的分數;如果成員不存在,則新增一個為0的成員。

到此這篇關於redis中資料型別命令整理的文章就介紹到這了,更多相關redis中5種資料型別基本命令介紹內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!