天天看點

NoSQL資料庫Redis使用指令簡介NoSQL 資料庫Redis使用指令簡介

NoSQL 資料庫Redis使用指令簡介

NOSQL資料庫可以按照它們的資料模型分成4類:

1.鍵-值對存儲庫(Key-Value)

redis……

2.BigTable實作(BigTable-implementations)

HBase

3.文檔庫(Document-stores)

mongo DB

4.圖形資料庫(Graph Database)

代表: Neo4j

Redis 操作簡介

服務啟動

redis服務啟動指令: redis-server /usr/local/etc/redis.conf

redis服務啟動後,可以使用redis 用戶端操作通路redis了: redis-cli

配置檢視

檢視配置項指令: CONFIG GET

在用戶端指令模式下,輸入config get * 可以看到redis服務所有的配置。

redis庫

redis服務預設有16個庫,從db0到db15,使用select 可以選擇指定的庫。

redis key

Redis的key和支援的資料類型及其操作

  1. keys

    redis本質上一個key-value db,是以我們首先來看看他的key.首先key也是字元串類型,但是key中不能包括邊界字元

    由于key不是binary safe的字元串,是以像”my key”和”mykey\n”這樣包含空格和換行的key是不允許的

    順便說一下在redis内部并不限制使用binary字元,這是redis協定限制的。”\r\n”在協定格式中會作為特殊字元。

  2. redis 1.2以後的協定中部分指令已經開始使用新的協定格式了(比如MSET)。
  3. 關于key的一個格式約定介紹下,object-type:id:field。比如user:1000:password,blog:xxidxx:title

    還有key的長度最好不要太長。道理很明顯占記憶體啊,而且查找時候相對短key也更慢。不過也推薦過短的key,

    比如u:1000:pwd,這樣的。顯然沒上面的user:1000:password可讀性好。

key相關操作指令

下面介紹下key相關的指令

1 DEL key 該指令用于在 key 存在是删除 key。

2 DUMP key 序列化給定 key ,并傳回被序列化的值。

3 EXISTS key 檢查給定 key 是否存在。

4 EXPIRE key seconds 為給定 key 設定過期時間。

5 EXPIREAT key timestamp EXPIREAT 的作用和 EXPIRE 類似,都用于為 key 設定過期時間。 不同在于 EXPIREAT 指令接受的時間參數是 UNIX 時間戳(unix timestamp)。

6 PEXPIRE key milliseconds 設定 key 的過期時間億以毫秒計。

7 PEXPIREAT key milliseconds-timestamp 設定 key 過期時間的時間戳(unix timestamp) 以毫秒計

8 KEYS pattern 查找所有符合給定模式( pattern)的 key 。

9 MOVE key db 将目前資料庫的 key 移動到給定的資料庫 db 當中。

10 PERSIST key 移除 key 的過期時間,key 将持久保持。

11 PTTL key 以毫秒為機關傳回 key 的剩餘的過期時間。

12 TTL key 以秒為機關,傳回給定 key 的剩餘生存時間(TTL, time to live)。

13 RANDOMKEY 從目前資料庫中随機傳回一個 key 。

14 RENAME key newkey 修改 key 的名稱

15 RENAMENX key newkey 僅當 newkey 不存在時,将 key 改名為 newkey 。

16 TYPE key 傳回 key 所儲存的值的類型。

del key1 key2 ….keyN 删除給定key,傳回删除key的數目,0表示給定key都不存在

type key 傳回給定key的value類型。傳回 none 表示不存在key,string字元類型,list 連結清單類型 set 無序集合類型…

redis> set testa dsf
OK
redis> set testb dsaf
OK
redis> set testc dff
OK

redis> keys t*
) "testb"
) "testc"
) "testa"

redis> keys test[ab]
) "testb"
) "testa"

redis> keys test*
) "testb"
) "testc"
) "testa"

redis> keys *
) "testb"
) "testa"
) "intval"
) "abc"
) "testc"
           

dbsize

傳回目前資料庫的key數量

select db-index

通過索引選擇資料庫,預設連接配接的資料庫所有是0,預設資料庫數是16個。傳回1表示成功,0失敗

rename oldkey newkey

原子的重命名一個key,如果newkey存在,将會被覆寫,傳回1表示成功,0失敗。可能是oldkey不存在或者和newkey相同

renamenx oldkey newkey

同上,但是如果newkey存在傳回失敗

expire key seconds

為key指定過期時間,機關是秒。傳回1成功,0表示key已經設定過過期時間或者不存在

ttl key

傳回設定過過期時間的key的剩餘過期秒數 -1表示key不存在或者沒有設定過過期時間

move key db-index

将key從目前資料庫移動到指定資料庫。傳回1成功。0 如果key不存在,或者已經在指定資料庫中

redis> keys a*
) "abc"
) "acc"
redis> move acc 
(integer) 
           

flushdb

删除 目前資料庫中所有key,此方法不會失敗。慎用

flushall

删除 所有資料庫中的所有key,此方法不會失敗。更加慎用

Redis支援的資料類型及其操作

資料類型

Redis支援五種類型的資料結構:

  • 字元串 (String)
  • 有序集合 (ZSet)
  • 集合 (Set)
  • 哈希 (Hash)
  • 清單 (List)

String(字元串)

string是redis最基本的類型,string類型是二進制安全的。意思是redis的string可以包含任何資料。

比如jpg圖檔或者序列化的對象 。string類型是Redis最基本的資料類型,一個鍵最大能存儲512MB。

Hash(哈希)

每個 hash 可以存儲 2^32 - 1 鍵值對(40多億)。在Redis裡,hash 是一個string類型的field和value的映射表,hash特别适合用于存儲對象。

是以,redis的hash對應了java、C#等語言裡的map。

List(清單)

Redis 的 list 類型其實就是一個每個子元素都是string類型的雙向連結清單。你可以将 元素添加到清單的頭和尾。

set(集合)

Redis的set是string類型的無序集合。set的是通過hash table實作的,是以添加,删除,查找的複雜度都是O(1)。

zset(sorted set:有序集合)

Redis zset 和 set 一樣也是string類型元素的集合,且不允許重複的成員。不同的是每個元素都會關聯一個double類型的score。

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

string操作

1   SET key value 設定指定 key 的值
2   GET key 擷取指定 key 的值。
3   GETRANGE key start end 傳回 key 中字元串值的子字元
4   GETSET key value 将給定 key 的值設為 value ,并傳回 key 的舊值(old value)。
5   GETBIT key offset 對 key 所儲存的字元串值,擷取指定偏移量上的位(bit)。
6   MGET key1 [key2..] 擷取所有(一個或多個)給定 key 的值。
7   SETBIT key offset value 對 key 所儲存的字元串值,設定或清除指定偏移量上的位(bit)。
8   SETEX key seconds value 将值 value 關聯到 key ,并将 key 的過期時間設為 seconds (以秒為機關)。
9   SETNX key value 隻有在 key 不存在時設定 key 的值。
10  SETRANGE key offset value 用 value 參數覆寫給定 key 所儲存的字元串值,從偏移量 offset 開始。
11  STRLEN key 傳回 key 所儲存的字元串值的長度。
12  MSET key value [key value ...] 同時設定一個或多個 key-value 對。
13  MSETNX key value [key value ...] 同時設定一個或多個 key-value 對,當且僅當所有給定 key 都不存在。
14  PSETEX key milliseconds value 這個指令和 SETEX 指令相似,但它以毫秒為機關設定 key 的生存時間,而不是像 SETEX 指令那樣,以秒為機關。
15  INCR key 将 key 中儲存的數字值增一。
16  INCRBY key increment 将 key 所儲存的值加上給定的增量值(increment) 。
17  INCRBYFLOAT key increment 将 key 所儲存的值加上給定的浮點增量值(increment) 。
18  DECR key 将 key 中儲存的數字值減一。
19  DECRBY key decrement key 所儲存的值減去給定的減量值(decrement) 。
20  APPEND key value 如果 key 已經存在并且是一個字元串, APPEND 指令将 value 追加到 key 原來的值的末尾。
           

INCR*和DECR*操作: 對整型值進行處理加減的操作。

:> get abc
"abc"
:> INCR abc
(error) ERR value is not an integer or out of range
:> TYPE abc
string
:> set intval 
OK
:> type intval
string
:> INCR intval
(integer) 
:> INCRBYFLOAT intval  
"3.15"
           

Hash操作

Redis hash 指令以H開頭,代表Hash。

下表列出了 redis hash 基本的相關指令:

序号 指令及描述

1 HDEL key field2 [field2] 删除一個或多個哈希表字段

2 HEXISTS key field 檢視哈希表 key 中,指定的字段是否存在。

3 HGET key field 擷取存儲在哈希表中指定字段的值

4 HGETALL key 擷取在哈希表中指定 key 的所有字段和值

5 HINCRBY key field increment 為哈希表 key 中的指定字段的整數值加上增量 increment 。

6 HINCRBYFLOAT key field increment 為哈希表 key 中的指定字段的浮點數值加上增量 increment 。

7 HKEYS key 擷取所有哈希表中的字段

8 HLEN key 擷取哈希表中字段的數量

9 HMGET key field1 [field2] 擷取所有給定字段的值

10 HMSET key field1 value1 [field2 value2 ] 同時将多個 field-value (域-值)對設定到哈希表 key 中。

11 HSET key field value 将哈希表 key 中的字段 field 的值設為 value 。

12 HSETNX key field value 隻有在字段 field 不存在時,設定哈希表字段的值。

13 HVALS key 擷取哈希表中所有值

14 HSCAN key cursor [MATCH pattern] [COUNT count] 疊代哈希表中的鍵值對。

:> HMSET product: name "redis tutorial" description "redis basic commands for caching" likes  visitors 
OK
redis :> HGETALL product:
) "name"
) "redis tutorial"
) "description"
) "redis basic commands for caching"
) "likes"
) "20"
) "visitors"
) "23000"

:[]> HLEN product:
(integer) 

:[]> HKEYS product:
) "name"
) "description"
) "likes"
) "visitors"

:[]> HGET  product: name
"redis tutorial"
:[]> HGET  product: likes
"20"

:[]> HINCRBY product: visitors 
(integer) 


Note: 
HINCRBY可以建立一個新的field:
:[]> HINCRBY product: visitoes 
(integer) 

:[]> HDEL product: visitoes
(integer) 

:[]> HGETALL product:
) "name"
) "redis tutorial"
) "description"
) "redis basic commands for caching"
) "likes"
) "20"
) "visitors"
) "23001"


:[]> HVALS product:
) "redis tutorial"
) "redis basic commands for caching"
) "20"
) "23001"
           

List

Redis清單是簡單的字元串清單,按照插入順序排序。你可以添加一個元素導清單的頭部(左邊)或者尾部(右邊).

一個清單最多可以包含 2^32 - 1 個元素 (4294967295, 每個清單超過40億個元素)。

Redis的清單操作指令大多以L開頭,代表List。

清單指令

下表列出了清單相關的基本指令:

B – Block, L – first, R – last

序号 指令及描述

1 BLPOP key1 [key2 ] timeout 移出并擷取清單的第一個元素, 如果清單沒有元素會阻塞(block)清單直到等待逾時或發現可彈出元素為止。

2 BRPOP key1 [key2 ] timeout 移出并擷取清單的最後一個元素, 如果清單沒有元素會阻塞清單直到等待逾時或發現可彈出元素為止。

3 BRPOPLPUSH source destination timeout 從清單中彈出一個值,将彈出的元素插入到另外一個清單中并傳回它; 如果清單沒有元素會阻塞清單直到等待逾時或發現可彈出元素為止。

4 LINDEX key index 通過索引擷取清單中的元素

5 LINSERT key BEFORE|AFTER pivot value 在清單的元素前或者後插入元素

6 LLEN key 擷取清單長度

7 LPOP key 移出并擷取清單的第一個元素

8 LPUSH key value1 [value2] 将一個或多個值插入到清單頭部

9 LPUSHX key value 将一個或多個值插入到已存在的清單頭部

10 LRANGE key start stop 擷取清單指定範圍内的元素

11 LREM key count value 移除清單元素

12 LSET key index value 通過索引設定清單元素的值

13 LTRIM key start stop 對一個清單進行修剪(trim),就是說,讓清單隻保留指定區間内的元素,不在指定區間之内的元素都将被删除。

14 RPOP key 移除并擷取清單最後一個元素

15 RPOPLPUSH source destination 移除清單的最後一個元素,并将該元素添加到另一個清單并傳回

16 RPUSH key value1 [value2] 在清單中添加一個或多個值

17 RPUSHX key value 為已存在的清單添加值

示例:

:[]> LPUSH product:book  redis
(integer) 
:[]> LPUSH product:book  mongodb
(integer) 
:[]> LPUSH product:book  mongodb in action
(integer) 
:[]> LPUSH product:book  "mongodb in action"
(integer) 

// 長度
:[]> LLEN product:book
(integer) 

// index 從0開始,指定的大于清單其長度時,擷取到最後的元素。
:[]> LRANGE product:book  
) "mongodb in action"
) "action"
) "in"
) "mongodb"
) "mongodb"
) "redis"

:[]> RPUSH product:book "spring in action"
(integer) 

:[]> LRANGE product:book  
) "mongodb in action"
) "action"
) "in"
) "mongodb"
) "mongodb"
) "redis"
) "spring in action"

// index: start from 0.
:[]> lset product:book  "what"
OK

:[]> LRANGE product:book  
) "mongodb in action"
) "action"
) "in"
) "what"
) "mongodb"
) "redis"
) "spring in action"

//
:[]> RPOP product:book
"spring in action"

:[]> LRANGE product:book  
) "mongodb in action"
) "action"
) "in"
) "what"
) "mongodb"
) "redis"

:[]> LPOP product:book
"mongodb in action"
:[]> LRANGE product:book  
) "action"
) "in"
) "what"
) "mongodb"
) "redis"
:[]> 


:[]> LINDEX product:book 
"in"
:[]> LRANGE product:book  
) "action"
) "in"
) "what"
) "mongodb"
) "redis"

// 移除元素 -- value必須指定正确,否則,不會移除。
:[]> lrem product:book   "what"
(integer) 
:[]> LRANGE product:book  
) "action"
) "in"
) "mongodb"
) "redis"
           

Redis 集合(Set)

Redis的Set是string類型的無序集合。集合成員是唯一的,這就意味着集合中不能出現重複的資料。

Redis中集合是通過哈希表實作的,是以添加,删除,查找的複雜度都是O(1)。

集合中最大的成員數為 2^32 - 1 (4294967295, 每個集合可存儲40多億個成員)。

Redis 集合指令

下表列出了 Redis 集合基本指令:集合的指令以S開頭,表示Set.

序号 指令及描述

1 SADD key member1 [member2] 向集合添加一個或多個成員

2 SCARD key 擷取集合的成員數

3 SDIFF key1 [key2] 傳回給定所有集合的差集

4 SDIFFSTORE destination key1 [key2] 傳回給定所有集合的差集并存儲在 destination 中

5 SINTER key1 [key2] 傳回給定所有集合的交集

6 SINTERSTORE destination key1 [key2] 傳回給定所有集合的交集并存儲在 destination 中

7 SISMEMBER key member 判斷 member 元素是否是集合 key 的成員

8 SMEMBERS key 傳回集合中的所有成員

9 SMOVE source destination member 将 member 元素從 source 集合移動到 destination 集合

10 SPOP key 移除并傳回集合中的一個随機元素

11 SRANDMEMBER key [count] 傳回集合中一個或多個随機數

12 SREM key member1 [member2] 移除集合中一個或多個成員

13 SUNION key1 [key2] 傳回所有給定集合的并集

14 SUNIONSTORE destination key1 [key2] 所有給定集合的并集存儲在 destination 集合中

15 SSCAN key cursor [MATCH pattern] [COUNT count] 疊代集合中的元素

示例:

:[]> select 
OK
:[]> dbsize
(integer) 
:[]> sadd product:set iphone
(integer) 
:[]> dbsize
(integer) 
:[]> sadd product:set nexus lumia
(integer) 
:[]> dbsize
(integer) 
:[]> SMEMBERS product:set
) "iphone"
) "lumia"
) "nexus"

:[]> sadd book:set "Spring in action" "redis in action"
(integer) 
:[]> SMEMBERS book:set
) "redis in action"
) "Spring in action"
:[]> SCARD
(error) ERR wrong number of arguments for 'scard' command
:[]> SCARD product
(integer) 
:[]> SCARD product:book
(integer) 
:[]> SCARD product:set
(integer) 
:[]> SCARD book:set
(integer) 


:[]> SUNION book:set product:set
) "iphone"
) "lumia"
) "Spring in action"
) "redis in action"
) "nexus"
:[]> Sinter  book:set product:set
(empty list or set)
:[]> sadd book:set iphone
(integer) 
:[]> Sinter  book:set product:set
) "iphone"
:[]> SDIFF book:set product:set
) "Spring in action"
) "redis in action"
:[]> SDIFF product:set  book:set
) "nexus"
) "lumia"
:[]> SDIFFSTORE product:other  product:set  book:set
(integer) 
:[]> SMEMBERS product:other
) "nexus"
) "lumia"
:[]> srem product:other nexus
(integer) 
:[]> SMEMBERS product:other
) "lumia"
:[]> smembers  book:set
) "iphone"
) "redis in action"
) "Spring in action"
:[]> sadd book:set "redis in action"
(integer) 
:[]> smembers  book:set
) "iphone"
) "redis in action"
) "Spring in action"
:[]> smembers  book:set
) "iphone"
) "redis in action"
) "Spring in action"
           

Redis 有序集合(sorted set)

Redis 有序集合和集合一樣也是string類型元素的集合,且不允許重複的成員。 集合是通過哈希表實作的,是以添加,删除,查找的複雜度都是O(1)。 集合中最大的成員數為 2^32 - 1 (4294967295, 每個集合可存儲40多億個成員)。

不同的是每個元素都會關聯一個double類型的分數。redis正是通過分數來為集合中的成員進行從小到大的排序。有序集合的成員是唯一的,但分數(score)卻可以重複。

Redis 有序集合指令

下表列出了 redis 有序集合的基本指令,指令以Z開頭:

序号 指令及描述

1 ZADD key score1 member1 [score2 member2] 向有序集合添加一個或多個成員,或者更新已存在成員的分數

2 ZCARD key 擷取有序集合的成員數

3 ZCOUNT key min max 計算在有序集合中指定區間分數的成員數

4 ZINCRBY key increment member 有序集合中對指定成員的分數加上增量 increment

5 ZINTERSTORE destination numkeys key [key …] 計算給定的一個或多個有序集的交集并将結果集存儲在新的有序集合 key 中

6 ZLEXCOUNT key min max 在有序集合中計算指定字典區間内成員數量

7 ZRANGE key start stop [WITHSCORES] 通過索引區間傳回有序集合成指定區間内的成員

8 ZRANGEBYLEX key min max [LIMIT offset count] 通過字典區間傳回有序集合的成員

9 ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT] 通過分數傳回有序集合指定區間内的成員

10 ZRANK key member 傳回有序集合中指定成員的索引

11 ZREM key member [member …] 移除有序集合中的一個或多個成員

12 ZREMRANGEBYLEX key min max 移除有序集合中給定的字典區間的所有成員

13 ZREMRANGEBYRANK key start stop 移除有序集合中給定的排名區間的所有成員

14 ZREMRANGEBYSCORE key min max 移除有序集合中給定的分數區間的所有成員

15 ZREVRANGE key start stop [WITHSCORES] 傳回有序集中指定區間内的成員,通過索引,分數從高到底

16 ZREVRANGEBYSCORE key max min [WITHSCORES] 傳回有序集中指定分數區間内的成員,分數從高到低排序

17 ZREVRANK key member 傳回有序集合中指定成員的排名,有序內建員按分數值遞減(從大到小)排序

18 ZSCORE key member 傳回有序集中,成員的分數值

19 ZUNIONSTORE destination numkeys key [key …] 計算給定的一個或多個有序集的并集,并存儲在新的 key 中

20 ZSCAN key cursor [MATCH pattern] [COUNT count] 疊代有序集合中的元素(包括元素成員和元素分值)

示例:

:[]> zadd product:major:lesson  java
(integer) 
:[]> dbsize
(integer) 
:[]> zadd product:major:lesson  mongodb
(integer) 
:[]> zadd product:major:lesson  redis
(integer) 
:[]> zadd product:major:lesson  mysql
(integer) 
:[]> dbsize
(integer) 

:[]> ZRANGE product:major:lesson   
) "java"
) "mongodb"
) "redis"
) "mysql"

:[]> ZRANGE product:major:lesson    withscores
) "java"
) "1"
) "mongodb"
) "2"
) "redis"
) "3"
) "mysql"
) "4"


//
:[]> ZRANGEBYSCOre product:major:lesson   
) "java"
) "mongodb"
) "redis"
) "mysql"
:[]> ZRANGEBYSCOre product:major:lesson   
) "mongodb"
) "redis"
) "mysql"

:[]> ZCARD product:major:lesson
(integer) 

:[]> ZCARD product:major:lesson
(integer) 
:[]> ZCOUNT product:major:lesson  
(integer) 
:[]> ZCOUNT product:major:lesson  
(integer) 

// 傳回zset指定member的score
:[]> ZSCORE product:major:lesson mysql
"4"

// 有序集合中指定成員的索引 -- start from 0.
:[]> ZRANK product:major:lesson mysql
(integer) 

// ZREVRange
:[]> ZREVRange  product:major:lesson   
) "mongodb"
) "java"
:[]> ZREVRange  product:major:lesson  
) "mongodb"
) "java"
:[]> ZREVRange  product:major:lesson   
) "mysql"
) "redis"
           

telnet方式連接配接redis

telnet> open .. 
Trying .....
Connected to localhost.
Escape character is '^]'.
dbdize
-ERR unknown command 'dbdize'
dbsize
:
keys t*
*3
$5
testb
$5
testa
$5
testc

keys *
*5
$5
testb
$5
testa
$6
intval
$3
abc
$5
testc
shutdown
Connection closed by foreign host.
           

關閉服務

使用shutdown指令來關閉服務。

#關閉指定端口的redis-server  
$redis-cli -p  shutdown 
           

或者在telnet連接配接後,輸入

shutdown

指令關閉服務。

繼續閱讀