Redis中的數(shù)據(jù)結(jié)構(gòu)與常用命令

開發(fā)系統(tǒng):Ubuntu 17.04
Redis驅(qū)動(dòng):StackExchange.Redis 1.2.3
Redis版本:3.2.1
開發(fā)平臺(tái):.NET Core

對于Redis的介紹這里只寫一句:Redis是一種基于內(nèi)存的高性能非關(guān)系型數(shù)據(jù)庫棒搜,它以kye-value的形式來存儲(chǔ)數(shù)據(jù)疹蛉。

核心對象

圖片來自:從搭建到應(yīng)用,一文讀懂Redis

RedisObject

圖片來自:對象處理機(jī)制

Redis五種數(shù)據(jù)結(jié)構(gòu)對應(yīng)的編碼方式

編碼指的是五種數(shù)據(jù)類型在Redis內(nèi)部的存儲(chǔ)方式力麸,一種數(shù)據(jù)類型可對應(yīng)多個(gè)編碼方式可款。

5種數(shù)據(jù)類型

Redis中包含5種數(shù)據(jù)類型:STRING、LIST克蚂、SET筑舅、HASH、ZSET陨舱。

Redis中的5中數(shù)據(jù)結(jié)構(gòu)(截圖出自《Redis in Action》)

Redis以key-value形式存儲(chǔ)數(shù)據(jù),其中key與value的關(guān)系可分為兩種

  • 1對1
    在Redis的STRING數(shù)據(jù)結(jié)構(gòu)中版仔,一個(gè)key對應(yīng)一個(gè)value游盲。
  • 1對*
    Redis中的其余四種數(shù)據(jù)結(jié)構(gòu),一個(gè)key可以對應(yīng)多個(gè)value蛮粮。

為了更直觀的說明key和value間的關(guān)系益缎,下面用幾張圖(圖片來自《Redis in Action》)來描述Redis中的五種數(shù)據(jù)結(jié)構(gòu):

STRING結(jié)構(gòu)
LIST結(jié)構(gòu)
SET結(jié)構(gòu)
HASH結(jié)構(gòu)
ZSET結(jié)構(gòu)

其中:
SET和ZSET中沒有重復(fù)元素;
相比SET然想,ZSET具有排序功能莺奔;
ZSET和HASH的value也是鍵值對形式:ZSET(score,member)、HASH(field,value)变泄;
STRING類型中不僅僅是存儲(chǔ)字符令哟,也可以存儲(chǔ)數(shù)值(整數(shù)、浮點(diǎn)數(shù))妨蛹;
5種數(shù)據(jù)結(jié)構(gòu)最終存儲(chǔ)的數(shù)據(jù)類型實(shí)際只有兩種:字符和數(shù)值屏富,Redis能夠區(qū)分存儲(chǔ)的值是字符還是數(shù)字;

Redis中常用命令

在redis-cli中對于輸入的命令會(huì)有智能提示

redis-cli
命令 作用
HELP 獲取命令的幫助信息蛙卤,學(xué)會(huì)help命令很重要
DEL 刪除key及對應(yīng)的值
EXPIRE 設(shè)置鍵的過期時(shí)間狠半,過期的鍵連同與該鍵相關(guān)的數(shù)據(jù)都將被刪除
help
  • STRING
    Redis對字符串提供了豐富的操作噩死,在Redis中STRING結(jié)構(gòu)用于存儲(chǔ)兩種類型的數(shù)據(jù):
    • 數(shù)值(整數(shù)、浮點(diǎn)數(shù))
    • 字符串(byte string)
命令 作用
SET 向指定的key中寫入值
GET 從指定的key中獲取值
INCR 將指定key的值加1
DECR 將指定key的值減1
INCRBY 將指定key的值加上指定的數(shù)值
DECRBY 將指定key的值減去指定的數(shù)值
APPEND 向value中追加內(nèi)容
GETRANGE GETRANGE key-name start end獲取指定索引范圍(字符串可看作是字符組成的數(shù)組)的字符神年,當(dāng)start=0且end=-1時(shí)獲取整個(gè)字符串
SETRANGE `設(shè)置指定偏移量的字符的值
GETBIT GETBIT key-name offset 將字符串看做是二進(jìn)制形式(bit string)已维,并返回指定偏移量位置處的二進(jìn)制位的值
SETBIT 設(shè)置指定偏移量位置處的二進(jìn)制位的值
BITCOUNT 返回字符串中二進(jìn)制位值為1的二進(jìn)制位數(shù)
BITOP 對字符串執(zhí)行位運(yùn)算,并將計(jì)算結(jié)果存儲(chǔ)到指定的key中

對于BITCOUNT命令已日,專門寫了一段程序進(jìn)行驗(yàn)證垛耳,效果圖如下:

c#代碼
redis-cli
  • LIST
命令 作用
LPUSH 將一個(gè)或多個(gè)值推入列表左端
RPUSH 將一個(gè)或多個(gè)值推入列表右端
LPOP 移除并返回列表最左端的值
RPOP 移除并返回列表最右端的值
LINDEX 根據(jù)索引獲取LIST中的值
LRANGE 獲取LIST中索引在指定范圍內(nèi)的值
LTRIM 從LIST中刪除索引不在指定范圍內(nèi)的值,這里的索引范圍是閉區(qū)間
  • HASH
HSET
命令 作用
HSET 向HASH表中添加元素捂敌,由上圖可以看出HASH結(jié)構(gòu)中存儲(chǔ)的值也是一個(gè)鍵值對(field value)
HMSET 一次向HASH表中寫入多個(gè)鍵值對
HGET 獲取HASH中存儲(chǔ)的值
HMGET 一次從HASH中獲取多個(gè)值
HLEN 獲取HASH表中存儲(chǔ)的元素個(gè)數(shù)
HDEL 刪除HASH表中的鍵值對
HEXISTS 判斷HASH中是否包含指定field的鍵值對
HKEYS 獲取HASH中的所有鍵(field)
HVALS 獲取HASH中的所有值
HGETALL 獲取HASH中的所有鍵值對
HINCRBY 將HASH中的指定value增加指定的數(shù)值
  • SET
    SET中沒有重復(fù)元素艾扮,向SET中添加重復(fù)的數(shù)據(jù)只會(huì)存儲(chǔ)一份。
命令 作用
SADD 向SET中添加元素
SREM 移除SET中的元素
SISMEMBER 判斷某元素是否存在于SET中
SCARD 返回SET中的元素個(gè)數(shù)
SMEMBERS 返回SET中的所有元素
SSCAN 通過迭代的方式返回SET中的所有元素
SMOVE 將元素從某一集(如果該元素存在當(dāng)前集合中)合移動(dòng)到另一集合并返回當(dāng)前元素

集合間運(yùn)算

命令 作用
SDIFF 對SET集合進(jìn)行補(bǔ)集運(yùn)算(存在于第一個(gè)集合且不存在于第二個(gè)集合中的元素)并返回運(yùn)算結(jié)果
SDIFFSTORE 對SET集合進(jìn)行補(bǔ)集運(yùn)算并將運(yùn)算結(jié)果存儲(chǔ)到一個(gè)新的SET集合中
SINTER 對SET集合進(jìn)行交集運(yùn)算并返回運(yùn)算結(jié)果
SINTERSTORE 對SET集合進(jìn)行交集運(yùn)算并將運(yùn)算結(jié)果存儲(chǔ)到一個(gè)新的SET集合中
SUNION 對SET集合進(jìn)行并集運(yùn)算并返回運(yùn)算結(jié)果
SUNIONSTORE 對SET集合進(jìn)行并集運(yùn)算并將運(yùn)算結(jié)果存儲(chǔ)到一個(gè)新的SET集合中
  • ZSET
    ZSET和SET一樣占婉,沒有重復(fù)元素泡嘴,但和SET相比它有排序功能。
命令 作用
ZADD 向ZSET中添加元素
ZREM 移除ZSET中的元素
ZCARD 獲取ZSET中元素的個(gè)數(shù)
ZSCORE 獲取ZSET中元素的score值
ZRANK 獲取ZSET中元素的索引
ZREMRANGEBYRANK 從ZSET中移除指定索引范圍內(nèi)的元素
ZREMRANGEBYSCORE 從ZSET中移除指定score范圍內(nèi)的元素
ZCOUNT 獲取ZSET中score值在指定范圍內(nèi)元素的個(gè)數(shù)
ZRANGE 獲取ZSET中索引在指定范圍內(nèi)的元素逆济,ZRANGE key start stop酌予,參數(shù)start=0且stop=-1時(shí)返回所有元素

集合間運(yùn)算

命令 作用
ZINTERSTORE 對ZSET集合進(jìn)行交集運(yùn)算并將運(yùn)算結(jié)果存儲(chǔ)到一個(gè)新的ZSET集合中
ZUNIONSTORE 對ZSET集合進(jìn)行并集運(yùn)算并將運(yùn)算結(jié)果存儲(chǔ)到一個(gè)新的ZSET集合中

集合運(yùn)算對于value值相同的集合元素score值的處理分為三種方式:

  1. 求和
  2. 取最大值
  3. 取最小值

執(zhí)行ZINTERSTORE命令(ZUNIONSTORE與之類似)

  • 參數(shù)destination表示用于存儲(chǔ)計(jì)算結(jié)果的集合的key
  • 參數(shù)numkeys表示參與運(yùn)算的集合數(shù),必選
  • AGGREGATE表示對score的操作方式奖慌,默認(rèn)為SUM
  • 參數(shù)WEIGHTS表示權(quán)重抛虫,該參數(shù)比較復(fù)雜:
    • 參數(shù)WEIGHTS的個(gè)數(shù)和numkyes值相等

    • AGGREGATE值為SUM時(shí),對于結(jié)果集中的某個(gè)value為a的元素B简僧,參與運(yùn)算的各個(gè)集合中value為a的元素的score值會(huì)分別和對應(yīng)的WEIGHTS值相乘然后再將各自相乘結(jié)果相加作為結(jié)果集中元素B的score值

    • AGGREGATE值為MIN或MAX時(shí)建椰,對于結(jié)果集中的某個(gè)value為a的元素B,參與運(yùn)算的各個(gè)集合中value為a的元素中score值最小或最大的那個(gè)(若有多個(gè)岛马,則按照命令行中指定集合的順序自左向右取第一個(gè)符合條件的集合中的元素)和對應(yīng)的WEIGHTS值相乘得到的值作為結(jié)果集中元素B的score值

規(guī)則略復(fù)雜棉姐,自己動(dòng)手寫幾遍就會(huì)明白了。


ZINTERSTORE

以下為進(jìn)行集合運(yùn)算的示意圖:
以對score求和的方式進(jìn)行交集運(yùn)算


交集運(yùn)算

以取score中最小值的方式進(jìn)行并集運(yùn)算


并集運(yùn)算

以對score求和的方式進(jìn)行并集運(yùn)算


并集運(yùn)算

Sort

對LIST啦逆、SET伞矩、ZSET三種數(shù)據(jù)結(jié)構(gòu)中的值進(jìn)行排序操作,默認(rèn)是正序排列夏志。

sort

Publish & Subscribe

發(fā)布/訂閱模式

命令 作用
PUBLISH 向指定的頻道發(fā)送二進(jìn)制字符串消息(binary string messages)
SUBSCRIBE 訂閱指定的頻道已接受該頻道發(fā)送的消息
UNSUBSCRIBE 取消訂閱某頻道

下圖中展示的是使用redis-cli和stackexchange.redis進(jìn)行的pub/sub測試效果:


pub/sub

Transcation

命令 作用
MULTI 表示事務(wù)的開始
EXEC 執(zhí)行事務(wù)中包含的命令

Redis中事務(wù)(調(diào)用MULTI表示事務(wù)的開始)所包含的命令會(huì)被放到一個(gè)隊(duì)列中乃坤,當(dāng)遇到EXEC命令后會(huì)不間斷的依次執(zhí)行隊(duì)列中的命令。


transaction

Redis中的事務(wù)和數(shù)據(jù)庫中的事務(wù)不同沟蔑,它沒有回滾操作湿诊。

Redis中的事務(wù),若某行命令執(zhí)行失敗不會(huì)影響其它命令的執(zhí)行(下圖中第二行命令執(zhí)行失敗瘦材,第一枫吧、三行成功執(zhí)行):

transaction in redis

StackExchange.Redis

StackExchange.Redis驅(qū)動(dòng)是用C#語言寫的Redis驅(qū)動(dòng),它的API在語義上和Redis命令是類似的宇色,在這里列舉下驅(qū)動(dòng)中常用的幾個(gè)類:

  • ConnectionMultiplexer
    表示一組相關(guān)的Redis服務(wù)器鏈接九杂,StackExchage.Redis官方建議盡可能復(fù)用該對象颁湖。

  • IDatabase
    該接口中定義了對5種數(shù)據(jù)結(jié)構(gòu)進(jìn)行操作的方法

  • RedisDatabase
    IDatabase的實(shí)現(xiàn)類

  • RedisKey
    存儲(chǔ)到Redis中的key

  • RedisValue
    存儲(chǔ)到Redis中的value,可用于表示STRING例隆、LIST甥捺、SET結(jié)構(gòu)中存儲(chǔ)的數(shù)據(jù)

  • HashEntry
    表示一個(gè)HASH鍵值對

  • SortedSetEntry
    表示一個(gè)ZSET元素

  • ISubscript
    訂閱接口

  • RedisChannel
    表示發(fā)布/訂閱中的頻道名

  • Subscription
    ConnectionMultiplexer中的私有密封類,封裝和訂閱相關(guān)的信息

結(jié)語

Redis是一種NoSql數(shù)據(jù)庫镀层,Redis服務(wù)器上默認(rèn)有16個(gè)數(shù)據(jù)庫镰禾,Redis常被拿來和Memcache做比較,網(wǎng)上有很多這方面的文章唱逢,各位看官請自行搜索吴侦。本文著重介紹了Redis中的5中數(shù)據(jù)結(jié)構(gòu)和一些常用的命令静汤,對于第三方驅(qū)動(dòng)則一筆帶過碾盐,因?yàn)樵诹私饬薘edis本身之后,可以很快的掌握第三方驅(qū)動(dòng)的使用吗垮。

推薦工具

RedisDesktopManager

推薦圖書

  • Redis in Action
RedisInAction

參考文章

An introduction to Redis data types and abstractions
從搭建到應(yīng)用痪枫,一文讀懂Redis
對象處理機(jī)制
深入剖析 redis 數(shù)據(jù)結(jié)構(gòu) redisObject

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末织堂,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子奶陈,更是在濱河造成了極大的恐慌易阳,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,651評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件吃粒,死亡現(xiàn)場離奇詭異潦俺,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)徐勃,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,468評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門黑竞,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人疏旨,你說我怎么就攤上這事≡幔” “怎么了檐涝?”我有些...
    開封第一講書人閱讀 162,931評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長法挨。 經(jīng)常有香客問我谁榜,道長,這世上最難降的妖魔是什么凡纳? 我笑而不...
    開封第一講書人閱讀 58,218評(píng)論 1 292
  • 正文 為了忘掉前任窃植,我火速辦了婚禮,結(jié)果婚禮上荐糜,老公的妹妹穿的比我還像新娘巷怜。我一直安慰自己葛超,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,234評(píng)論 6 388
  • 文/花漫 我一把揭開白布延塑。 她就那樣靜靜地躺著绣张,像睡著了一般。 火紅的嫁衣襯著肌膚如雪关带。 梳的紋絲不亂的頭發(fā)上侥涵,一...
    開封第一講書人閱讀 51,198評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音宋雏,去河邊找鬼芜飘。 笑死,一個(gè)胖子當(dāng)著我的面吹牛磨总,可吹牛的內(nèi)容都是我干的嗦明。 我是一名探鬼主播,決...
    沈念sama閱讀 40,084評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼舍败,長吁一口氣:“原來是場噩夢啊……” “哼招狸!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起邻薯,我...
    開封第一講書人閱讀 38,926評(píng)論 0 274
  • 序言:老撾萬榮一對情侶失蹤裙戏,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后厕诡,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體累榜,經(jīng)...
    沈念sama閱讀 45,341評(píng)論 1 311
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,563評(píng)論 2 333
  • 正文 我和宋清朗相戀三年灵嫌,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了壹罚。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,731評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡寿羞,死狀恐怖猖凛,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情绪穆,我是刑警寧澤辨泳,帶...
    沈念sama閱讀 35,430評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站玖院,受9級(jí)特大地震影響菠红,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜难菌,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,036評(píng)論 3 326
  • 文/蒙蒙 一试溯、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧郊酒,春花似錦遇绞、人聲如沸键袱。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,676評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽杠纵。三九已至,卻和暖如春钩骇,著一層夾襖步出監(jiān)牢的瞬間比藻,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,829評(píng)論 1 269
  • 我被黑心中介騙來泰國打工倘屹, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留银亲,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,743評(píng)論 2 368
  • 正文 我出身青樓纽匙,卻偏偏與公主長得像务蝠,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子烛缔,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,629評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容