亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Redis數(shù)據(jù)類型string和Hash詳解

 更新時間:2022年03月04日 11:59:27   作者:灰小猿  
大家都知道Redis中有五大數(shù)據(jù)類型分別是String、List、Set、Hash和Zset,本文給大家分享Redis數(shù)據(jù)類型string和Hash的相關(guān)操作,感興趣的朋友跟隨小編一起看看吧

摘要:Redis中有五大數(shù)據(jù)類型,分別是String、List、Set、Hash和Zset。

先問大家一個問題:你知道Java的數(shù)據(jù)類型有哪些嗎?很多小伙伴肯定會直接想到int、byte、string等等~~~但是如果這樣回答就錯啦!

Java中的數(shù)據(jù)類型包括:基本數(shù)據(jù)類型和引用數(shù)據(jù)類型,其中基本數(shù)據(jù)類型包括:byte、short、int、long、double、float、char、boolean八種,而引用數(shù)據(jù)類型則是另外三種,分別是類、接口和數(shù)組!注意是沒有string類型的,這可是面試的一個坑哈!

而在Redis中也是有數(shù)據(jù)類型的,和Java中有所不同,在Redis中有五大數(shù)據(jù)類型,分別是String、List、Set、Hash和Zset。而這五種數(shù)據(jù)類型中的每一個,都對應(yīng)著很多不同的使用場景。接下來我們就先來學(xué)習(xí)一下在Redis中操作string和Hash字符串的命令有哪些?

String類型命令操作

String類型是在Redis中最常用的數(shù)據(jù)類型,它也是很多程序員在日常開發(fā)中最常使用甚至只會用的數(shù)據(jù)類型,這也就導(dǎo)致很多人在使用Redis的時候,就只知道使用string類型,而忽視了其他數(shù)據(jù)類型的重要性。所以我也希望大家在學(xué)習(xí)完這篇文章之后,對Redis中的數(shù)據(jù)類型有一個新的認(rèn)識,不要只使用String類型進行Redis的操作啦!

注意:在Redis的客戶端中進行操作之前,一定要保證Redis的服務(wù)器界面處于開啟狀態(tài),否則會出現(xiàn)客戶端拒絕訪問或打不開的情況哈!

設(shè)置指定key的值

Redis中給string類型的數(shù)據(jù)設(shè)置指定key的方法就是最基本的設(shè)置key-value的方法,

語法如下:

SET key value
? ? key為索引
? ? value為對應(yīng)的值

例如我們要設(shè)置索引為k3,值為v3的鍵值對數(shù)據(jù)

127.0.0.1:6379> SET k3 v3
OK

返回值為ok,則說明設(shè)置成功!

獲取指定key的值

如果我們已經(jīng)在Redis中設(shè)置了數(shù)據(jù),那么我們可以通過該數(shù)據(jù)的key來獲取它,語法格式如下:

GET key
? ? key為要獲取的值對應(yīng)的索引

例如我們獲取剛才輸入的索引為k3,值為v3的數(shù)據(jù),如果該索引存在,那么將會返回對應(yīng)的值,如果不存在就會返回(nil)也就是null的意思。

127.0.0.1:6379> GET k3
"v3"
127.0.0.1:6379> GET k4
(nil)

返回key中字符串值的子串

這個命令的作用是獲取Redis中已經(jīng)存在的字符串的子串,同時我們可以指定一個下標(biāo)索引,指定要獲取哪一段字符。命令的格式如下:

GETRANGE key start end
    key為字符串的索引
    start為截取的起始下標(biāo)
    end為截取的終止下標(biāo)

比如我們截取索引為“mykey”,值為“huixiaoyuan”的數(shù)據(jù)的子串,

127.0.0.1:6379> GETRANGE mykey 2 5
"ixia"
127.0.0.1:6379> GETRANGE mykey 2 -1
"ixiaoyuan"
127.0.0.1:6379> GETRANGE mykey 1 100
"uixiaoyuan"

講解一下上面的代碼,因為字符串的起始下標(biāo)是0,所以第2個對應(yīng)的字符是“i”,如果想要截取字符串從某一個字符到最后部分的子串,那么可以直接將最后一個參數(shù)設(shè)置為-1.

如果你設(shè)置的獲取子串的范圍比較大,已經(jīng)超出了字符串原本的長度,那么只會返回到字符串的最后一個字符!

獲取多個給定key的值

與GET命令不同,GET命令只能獲取一個key對應(yīng)的值,而這個命令可以用于獲取多個key對應(yīng)的值,格式如下:

MGET key1 [key2...]
? ? 在MGET的后面可以追加多個索引,以空格分開

如我們來獲取一下mykey、mykey1、mykey2分別對應(yīng)的值,

127.0.0.1:6379> MGET mykey mykey1 mykey2
1) "huixiaoyuan"
2) "value1"
3) "value2"

返回key所對應(yīng)的字符串的長度

這個命令的作用是獲取到當(dāng)前索引對應(yīng)的字符串的長度,格式如下:

STRLEN key
? ? key為字符串對應(yīng)的索引
127.0.0.1:6379> STRLEN mykey
(integer) 11

設(shè)置一個或多個鍵值對

我們知道SET命令的作用是設(shè)置一個鍵值對,但是如果有多個鍵值對同時設(shè)置呢?這個時候就可以使用這個命令了,格式如下:

MSET key1 value1 [key2 value2 ...]
    key1 value1為要設(shè)置的第一個鍵值對,之后的以空格分隔

如下我們設(shè)置同時設(shè)置三個鍵值對

127.0.0.1:6379> MSET k1 v1 k2 v2 k3 v3
OK

和上面這個命令相對的還有一個,該命令僅能在key不存在的情況下才能設(shè)置,否則所有的key-value都將會賦值失敗,格式如下:

MSETNX key1 value1 [key2 value2 ...]
    key1 value1為要設(shè)置的第一個鍵值對,之后的以空格分隔

如我們給已經(jīng)存在的k4設(shè)置值,那么返回0,說明設(shè)置失敗,如果設(shè)置成功,則會返回1

127.0.0.1:6379> MSETNX k1 v1 k4 v4
(integer) 0
127.0.0.1:6379> MSETNX k4 v4 k5 v5
(integer) 1

將key中所存儲的數(shù)值加一

這個命令可以將我們存儲的字符的值加1,之后返回相加后的結(jié)果,但是如果該key對應(yīng)的字符不是一個數(shù)的話,就會返回一個錯誤信息,格式如下:

INCR key
????key為要加1的數(shù)對應(yīng)的索引

如下我們給剛才設(shè)置的k8加1,那么就會報錯,重新設(shè)置一個數(shù)值的鍵值對,再進行加1,就可以返回對應(yīng)的數(shù)據(jù)

127.0.0.1:6379> INCR k8
(error) ERR value is not an integer or out of range
127.0.0.1:6379> SET num1 10
OK
127.0.0.1:6379> INCR num1
(integer) 11

與INCR 命令對應(yīng)的還有一個INCRBY 該命令可以給指定的key對應(yīng)的數(shù)據(jù)加上指定的增量,格式如下:

INCRBY key increment

    key為索引
    increment為要增加的值
127.0.0.1:6379> INCRBY num1 5
(integer) 16

將key中所存儲的數(shù)值減一

既然存在增加的操作,那么對應(yīng)著也就是存在減少的操作,格式如下:

DECR key
    key為要加1的數(shù)對應(yīng)的索引

上一步我們將num1對應(yīng)的數(shù)值加5后得到16,現(xiàn)在我們對其進行減一操作。

127.0.0.1:6379> DECR num1
(integer) 15

與這個命令對應(yīng)的還有減指定的數(shù)據(jù)的命令,格式如下:

DECRBY key increment
    key為索引
    decrement為要增加的值
127.0.0.1:6379> DECRBY num1 2
(integer) 13

字符串追加

如果 key 已經(jīng)存在并且是一個字符串, APPEND 命令將指定的 value 追加到該 key 原來值(value)的末尾。返回的是追加后的長度,格式如下:

APPEND key value
    key為索引
    value為要追加的字符串

如我們在mykey1-value1的后面追加“hello”

127.0.0.1:6379> APPEND mykey1 hello
(integer) 11
127.0.0.1:6379> GET mykey1
"value1hello"

Hash類型

Hash類型是一個String類型的field(字段)和value(值)的映射表,它的作用是可以用來存儲我們定義的數(shù)據(jù)對象,所以簡單來說它是一個key下面存儲了多個key-value的情況,給大家簡單的話一個Hash的結(jié)構(gòu)圖:

接下來我們來簡單講一下在Redis中對于Hash這種數(shù)據(jù)類型,常用的幾個命令,

設(shè)置一個Hash數(shù)據(jù)

設(shè)置Hash數(shù)據(jù)所使用的命令不是SET,而是HMSET,你可以理解為H代表Hash的意思,M代表Map的意思,該命令的格式如下:

HMSET key fieId1 value1 [fieId2 value2…]

  • key為這個Hash數(shù)據(jù)對應(yīng)的唯一性索引
  • field為下面存儲的一個鍵值對的鍵
  • value為該鍵對應(yīng)的值

如我們設(shè)置key為“myhash”,里面存儲的field分別為name-huixiaoyuan、sex-nan、age-3的三個鍵值對

127.0.0.1:6379> HMSET myhash name huixiaoyuan sex nan age 3
OK

獲取指定哈希表中所有的字段和值

查看指定哈希表中所有的字段和值的命令是HGETALL,作用是取出該hash中所有的數(shù)據(jù),格式如下

HGETALL key

  • 其中key為對應(yīng)著這個Hash數(shù)據(jù)的索引

如我們查看剛才設(shè)置的hash數(shù)據(jù)

127.0.0.1:6379> HGETALL myhash
1) "name"
2) "huixiaoyuan"
3) "sex"
4) "nan"
5) "age"
6) "3"

獲取存儲在哈希表中指定字段的值

上一個命令是獲取所有的字段,那么現(xiàn)在這個命令是只獲取指定哈希表中指定字段的值,命令的格式如下:

HGET key field

  • key哈希表的索引
  • field獲取的值對應(yīng)的字段

如我們獲取上面的哈希表中字段為name對應(yīng)的值

127.0.0.1:6379> HGET myhash name
"huixiaoyuan"

刪除一個或多個哈希表字段

刪除一個或多個哈希表字段的命令是HDEL,該命令可以刪除指定哈希表中指定的字段,以及其對應(yīng)的值,格式如下:

HDEL key field1 [field2…]

  • key為指定的哈希表的索引
  • field為要刪除的值對應(yīng)的字段,如果要刪除多個就以空格分開

如我們要刪除索引為“myhash”的哈希表中值為“3”,對應(yīng)字段為“age”的字段和值為“nan”,對應(yīng)字段為“sex”的兩個字段。

127.0.0.1:6379> HGET myhash name
"huixiaoyuan"
127.0.0.1:6379> HDEL myhash age sex
(integer) 2
127.0.0.1:6379> HGETALL myhash
1) "name"
2) "huixiaoyuan"

獲取哈希表中字段的數(shù)量

該命令可以獲取指定哈希表中字段的數(shù)量,格式如下:

HLEN key

  • key為指定的哈希表的索引
127.0.0.1:6379> HLEN myhash
(integer) 1

獲取哈希表中的所有字段

該命令可以獲取指定哈希表中所有的字段,但是不返回字段對應(yīng)的值,格式如下:

HKEYS key

  • key為指定的哈希表的索引
127.0.0.1:6379> HKEYS myhash
1) "name"

獲取哈希表中所有的值

上一個命令是獲取到指定哈希表中所有的字段,但是不返回字段對應(yīng)的值,那么這個命令就是獲取到所有的值,而不返回其對應(yīng)的字段,格式如下:

HVALS key

  • key為指定的哈希表的索引
127.0.0.1:6379> HVALS myhash
1) "huixiaoyuan"

到此這篇關(guān)于Redis數(shù)據(jù)類型string和Hash詳解的文章就介紹到這了,更多相關(guān)Redis數(shù)據(jù)類型內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Redis常用數(shù)據(jù)類型命令實例匯總

    Redis常用數(shù)據(jù)類型命令實例匯總

    這篇文章主要介紹了Redis常用數(shù)據(jù)類型命令實例匯總,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-10-10
  • Windows中redis設(shè)置密碼的兩種方法

    Windows中redis設(shè)置密碼的兩種方法

    之前寫的一個項目,有項目代碼,有數(shù)據(jù)庫,但是本地沒redis,沒法跑此項目,故思考在本地安裝一個redis做登錄session存儲,所以開始動手實踐,下面這篇文章主要給大家介紹了關(guān)于Windows中redis設(shè)置密碼的兩種方法,需要的朋友可以參考下
    2023-04-04
  • Redis數(shù)據(jù)結(jié)構(gòu)之intset整數(shù)集合使用學(xué)習(xí)

    Redis數(shù)據(jù)結(jié)構(gòu)之intset整數(shù)集合使用學(xué)習(xí)

    這篇文章主要為大家介紹了Redis數(shù)據(jù)結(jié)構(gòu)之整數(shù)集合使用學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07
  • Redis數(shù)組和鏈表深入詳解

    Redis數(shù)組和鏈表深入詳解

    這篇文章主要介紹了Redis數(shù)組和鏈表深入詳解,這是redis的基礎(chǔ)的知識點,有感興趣的同學(xué)可以學(xué)習(xí)下
    2021-03-03
  • 單線程Redis快的4 個原因總結(jié)

    單線程Redis快的4 個原因總結(jié)

    作為內(nèi)存中數(shù)據(jù)存儲,Redis 以其速度和性能著稱,通常被用作大多數(shù)后端服務(wù)的緩存解決方案,但是,在內(nèi)部,Redis 采用單線程架構(gòu),為什么單線程設(shè)計依然會有這么高的性能,在本文中,讓我們深入探討為什么 Redis 才有單線程架構(gòu)
    2023-07-07
  • Redis 實現(xiàn)“附近的人”功能

    Redis 實現(xiàn)“附近的人”功能

    Redis基于geohash和有序集合提供了地理位置相關(guān)功能。這篇文章主要介紹了Redis 實現(xiàn)“附近的人”功能,需要的朋友可以參考下
    2019-11-11
  • 使用SpringBoot?+?Redis?實現(xiàn)接口限流的方式

    使用SpringBoot?+?Redis?實現(xiàn)接口限流的方式

    這篇文章主要介紹了SpringBoot?+?Redis?實現(xiàn)接口限流,Redis?除了做緩存,還能干很多很多事情:分布式鎖、限流、處理請求接口冪等,文中給大家提到了限流注解的創(chuàng)建方式,需要的朋友可以參考下
    2022-05-05
  • 詳解redis big key 排查思路

    詳解redis big key 排查思路

    本文主要介紹了詳解redis big key 排查思路,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • 淺談我是如何用redis做實時訂閱推送的

    淺談我是如何用redis做實時訂閱推送的

    這篇文章主要介紹了淺談我是如何用redis做實時訂閱推送的,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • Redis高可用之持久化

    Redis高可用之持久化

    在web服務(wù)器中,高可用是指服務(wù)器可以正常訪問的時間,衡量的標(biāo)準(zhǔn)是在多長時間內(nèi)可以提供正常服務(wù)(99.9%、99.99%、99.999%等等),Redis中,實現(xiàn)高可用的技術(shù)主要包括持久化、主從復(fù)制、哨兵和cluster集群,感興趣的同學(xué)可以閱讀本文
    2023-04-04

最新評論