NoSQL数据库Redis使用命令简介
NoSQL 數(shù)據(jù)庫Redis使用命令簡介
NOSQL數(shù)據(jù)庫可以按照它們的數(shù)據(jù)模型分成4類:
1.鍵-值對存儲(chǔ)庫(Key-Value)
redis……
2.BigTable實(shí)現(xiàn)(BigTable-implementations)
HBase
3.文檔庫(Document-stores)
mongo DB
4.圖形數(shù)據(jù)庫(Graph Database)
代表: Neo4j
Redis 操作簡介
服務(wù)啟動(dòng)
redis服務(wù)啟動(dòng)命令: redis-server /usr/local/etc/redis.conf
redis服務(wù)啟動(dòng)后,可以使用redis 客戶端操作訪問redis了: redis-cli
配置查看
查看配置項(xiàng)命令: CONFIG GET
在客戶端命令模式下,輸入config get * 可以看到redis服務(wù)所有的配置。
redis庫
redis服務(wù)缺省有16個(gè)庫,從db0到db15,使用select 可以選擇指定的庫。
redis key
Redis的key和支持的數(shù)據(jù)類型及其操作
redis本質(zhì)上一個(gè)key-value db,所以我們首先來看看他的key.首先key也是字符串類型,但是key中不能包括邊界字符
由于key不是binary safe的字符串,所以像”my key”和”mykey\n”這樣包含空格和換行的key是不允許的
順便說一下在redis內(nèi)部并不限制使用binary字符,這是redis協(xié)議限制的。”\r\n”在協(xié)議格式中會(huì)作為特殊字符。
redis 1.2以后的協(xié)議中部分命令已經(jīng)開始使用新的協(xié)議格式了(比如MSET)。
關(guān)于key的一個(gè)格式約定介紹下,object-type:id:field。比如user:1000:password,blog:xxidxx:title
還有key的長度最好不要太長。道理很明顯占內(nèi)存啊,而且查找時(shí)候相對短key也更慢。不過也推薦過短的key,
比如u:1000:pwd,這樣的。顯然沒上面的user:1000:password可讀性好。
key相關(guān)操作命令
下面介紹下key相關(guān)的命令
1 DEL key 該命令用于在 key 存在是刪除 key。
2 DUMP key 序列化給定 key ,并返回被序列化的值。
3 EXISTS key 檢查給定 key 是否存在。
4 EXPIRE key seconds 為給定 key 設(shè)置過期時(shí)間。
5 EXPIREAT key timestamp EXPIREAT 的作用和 EXPIRE 類似,都用于為 key 設(shè)置過期時(shí)間。 不同在于 EXPIREAT 命令接受的時(shí)間參數(shù)是 UNIX 時(shí)間戳(unix timestamp)。
6 PEXPIRE key milliseconds 設(shè)置 key 的過期時(shí)間億以毫秒計(jì)。
7 PEXPIREAT key milliseconds-timestamp 設(shè)置 key 過期時(shí)間的時(shí)間戳(unix timestamp) 以毫秒計(jì)
8 KEYS pattern 查找所有符合給定模式( pattern)的 key 。
9 MOVE key db 將當(dāng)前數(shù)據(jù)庫的 key 移動(dòng)到給定的數(shù)據(jù)庫 db 當(dāng)中。
10 PERSIST key 移除 key 的過期時(shí)間,key 將持久保持。
11 PTTL key 以毫秒為單位返回 key 的剩余的過期時(shí)間。
12 TTL key 以秒為單位,返回給定 key 的剩余生存時(shí)間(TTL, time to live)。
13 RANDOMKEY 從當(dāng)前數(shù)據(jù)庫中隨機(jī)返回一個(gè) key 。
14 RENAME key newkey 修改 key 的名稱
15 RENAMENX key newkey 僅當(dāng) newkey 不存在時(shí),將 key 改名為 newkey 。
16 TYPE key 返回 key 所儲(chǔ)存的值的類型。
del key1 key2 ….keyN 刪除給定key,返回刪除key的數(shù)目,0表示給定key都不存在
type key 返回給定key的value類型。返回 none 表示不存在key,string字符類型,list 鏈表類型 set 無序集合類型…
dbsize 返回當(dāng)前數(shù)據(jù)庫的key數(shù)量
select db-index 通過索引選擇數(shù)據(jù)庫,默認(rèn)連接的數(shù)據(jù)庫所有是0,默認(rèn)數(shù)據(jù)庫數(shù)是16個(gè)。返回1表示成功,0失敗
rename oldkey newkey 原子的重命名一個(gè)key,如果newkey存在,將會(huì)被覆蓋,返回1表示成功,0失敗。可能是oldkey不存在或者和newkey相同
renamenx oldkey newkey 同上,但是如果newkey存在返回失敗
expire key seconds 為key指定過期時(shí)間,單位是秒。返回1成功,0表示key已經(jīng)設(shè)置過過期時(shí)間或者不存在
ttl key 返回設(shè)置過過期時(shí)間的key的剩余過期秒數(shù) -1表示key不存在或者沒有設(shè)置過過期時(shí)間
move key db-index 將key從當(dāng)前數(shù)據(jù)庫移動(dòng)到指定數(shù)據(jù)庫。返回1成功。0 如果key不存在,或者已經(jīng)在指定數(shù)據(jù)庫中
redis> keys a* 1) "abc" 2) "acc" redis> move acc 1 (integer) 1flushdb 刪除 當(dāng)前數(shù)據(jù)庫中所有key,此方法不會(huì)失敗。慎用
flushall 刪除 所有數(shù)據(jù)庫中的所有key,此方法不會(huì)失敗。更加慎用
Redis支持的數(shù)據(jù)類型及其操作
數(shù)據(jù)類型
Redis支持五種類型的數(shù)據(jù)結(jié)構(gòu):
- 字符串 (String)
- 有序集合 (ZSet)
- 集合 (Set)
- 哈希 (Hash)
- 列表 (List)
String(字符串)
string是redis最基本的類型,string類型是二進(jìn)制安全的。意思是redis的string可以包含任何數(shù)據(jù)。
比如jpg圖片或者序列化的對象 。string類型是Redis最基本的數(shù)據(jù)類型,一個(gè)鍵最大能存儲(chǔ)512MB。
Hash(哈希)
每個(gè) hash 可以存儲(chǔ) 2^32 - 1 鍵值對(40多億)。在Redis里,hash 是一個(gè)string類型的field和value的映射表,hash特別適合用于存儲(chǔ)對象。
所以,redis的hash對應(yīng)了java、C#等語言里的map。
List(列表)
Redis 的 list 類型其實(shí)就是一個(gè)每個(gè)子元素都是string類型的雙向鏈表。你可以將 元素添加到列表的頭和尾。
set(集合)
Redis的set是string類型的無序集合。set的是通過hash table實(shí)現(xiàn)的,所以添加,刪除,查找的復(fù)雜度都是O(1)。
zset(sorted set:有序集合)
Redis zset 和 set 一樣也是string類型元素的集合,且不允許重復(fù)的成員。不同的是每個(gè)元素都會(huì)關(guān)聯(lián)一個(gè)double類型的score。
redis正是通過分?jǐn)?shù)來為集合中的成員進(jìn)行從小到大的排序。zset的成員是唯一的,但分?jǐn)?shù)(score)卻可以重復(fù)。
string操作
1 SET key value 設(shè)置指定 key 的值 2 GET key 獲取指定 key 的值。 3 GETRANGE key start end 返回 key 中字符串值的子字符 4 GETSET key value 將給定 key 的值設(shè)為 value ,并返回 key 的舊值(old value)。 5 GETBIT key offset 對 key 所儲(chǔ)存的字符串值,獲取指定偏移量上的位(bit)。 6 MGET key1 [key2..] 獲取所有(一個(gè)或多個(gè))給定 key 的值。 7 SETBIT key offset value 對 key 所儲(chǔ)存的字符串值,設(shè)置或清除指定偏移量上的位(bit)。 8 SETEX key seconds value 將值 value 關(guān)聯(lián)到 key ,并將 key 的過期時(shí)間設(shè)為 seconds (以秒為單位)。 9 SETNX key value 只有在 key 不存在時(shí)設(shè)置 key 的值。 10 SETRANGE key offset value 用 value 參數(shù)覆寫給定 key 所儲(chǔ)存的字符串值,從偏移量 offset 開始。 11 STRLEN key 返回 key 所儲(chǔ)存的字符串值的長度。 12 MSET key value [key value ...] 同時(shí)設(shè)置一個(gè)或多個(gè) key-value 對。 13 MSETNX key value [key value ...] 同時(shí)設(shè)置一個(gè)或多個(gè) key-value 對,當(dāng)且僅當(dāng)所有給定 key 都不存在。 14 PSETEX key milliseconds value 這個(gè)命令和 SETEX 命令相似,但它以毫秒為單位設(shè)置 key 的生存時(shí)間,而不是像 SETEX 命令那樣,以秒為單位。 15 INCR key 將 key 中儲(chǔ)存的數(shù)字值增一。 16 INCRBY key increment 將 key 所儲(chǔ)存的值加上給定的增量值(increment) 。 17 INCRBYFLOAT key increment 將 key 所儲(chǔ)存的值加上給定的浮點(diǎn)增量值(increment) 。 18 DECR key 將 key 中儲(chǔ)存的數(shù)字值減一。 19 DECRBY key decrement key 所儲(chǔ)存的值減去給定的減量值(decrement) 。 20 APPEND key value 如果 key 已經(jīng)存在并且是一個(gè)字符串, APPEND 命令將 value 追加到 key 原來的值的末尾。INCR*和DECR*操作: 對整型值進(jìn)行處理加減的操作。
127.0.0.1:6379> get abc "abc" 127.0.0.1:6379> INCR abc (error) ERR value is not an integer or out of range 127.0.0.1:6379> TYPE abc string 127.0.0.1:6379> set intval 2 OK 127.0.0.1:6379> type intval string 127.0.0.1:6379> INCR intval (integer) 3 127.0.0.1:6379> INCRBYFLOAT intval 0.15 "3.15"Hash操作
Redis hash 命令以H開頭,代表Hash。
下表列出了 redis hash 基本的相關(guān)命令:
序號(hào) 命令及描述
1 HDEL key field2 [field2] 刪除一個(gè)或多個(gè)哈希表字段
2 HEXISTS key field 查看哈希表 key 中,指定的字段是否存在。
3 HGET key field 獲取存儲(chǔ)在哈希表中指定字段的值
4 HGETALL key 獲取在哈希表中指定 key 的所有字段和值
5 HINCRBY key field increment 為哈希表 key 中的指定字段的整數(shù)值加上增量 increment 。
6 HINCRBYFLOAT key field increment 為哈希表 key 中的指定字段的浮點(diǎn)數(shù)值加上增量 increment 。
7 HKEYS key 獲取所有哈希表中的字段
8 HLEN key 獲取哈希表中字段的數(shù)量
9 HMGET key field1 [field2] 獲取所有給定字段的值
10 HMSET key field1 value1 [field2 value2 ] 同時(shí)將多個(gè) field-value (域-值)對設(shè)置到哈希表 key 中。
11 HSET key field value 將哈希表 key 中的字段 field 的值設(shè)為 value 。
12 HSETNX key field value 只有在字段 field 不存在時(shí),設(shè)置哈希表字段的值。
13 HVALS key 獲取哈希表中所有值
14 HSCAN key cursor [MATCH pattern] [COUNT count] 迭代哈希表中的鍵值對。
List
Redis列表是簡單的字符串列表,按照插入順序排序。你可以添加一個(gè)元素導(dǎo)列表的頭部(左邊)或者尾部(右邊).
一個(gè)列表最多可以包含 2^32 - 1 個(gè)元素 (4294967295, 每個(gè)列表超過40億個(gè)元素)。
Redis的列表操作命令大多以L開頭,代表List。
列表命令
下表列出了列表相關(guān)的基本命令:
B – Block, L – first, R – last
序號(hào) 命令及描述
1 BLPOP key1 [key2 ] timeout 移出并獲取列表的第一個(gè)元素, 如果列表沒有元素會(huì)阻塞(block)列表直到等待超時(shí)或發(fā)現(xiàn)可彈出元素為止。
2 BRPOP key1 [key2 ] timeout 移出并獲取列表的最后一個(gè)元素, 如果列表沒有元素會(huì)阻塞列表直到等待超時(shí)或發(fā)現(xiàn)可彈出元素為止。
3 BRPOPLPUSH source destination timeout 從列表中彈出一個(gè)值,將彈出的元素插入到另外一個(gè)列表中并返回它; 如果列表沒有元素會(huì)阻塞列表直到等待超時(shí)或發(fā)現(xiàn)可彈出元素為止。
4 LINDEX key index 通過索引獲取列表中的元素
5 LINSERT key BEFORE|AFTER pivot value 在列表的元素前或者后插入元素
6 LLEN key 獲取列表長度
7 LPOP key 移出并獲取列表的第一個(gè)元素
8 LPUSH key value1 [value2] 將一個(gè)或多個(gè)值插入到列表頭部
9 LPUSHX key value 將一個(gè)或多個(gè)值插入到已存在的列表頭部
10 LRANGE key start stop 獲取列表指定范圍內(nèi)的元素
11 LREM key count value 移除列表元素
12 LSET key index value 通過索引設(shè)置列表元素的值
13 LTRIM key start stop 對一個(gè)列表進(jìn)行修剪(trim),就是說,讓列表只保留指定區(qū)間內(nèi)的元素,不在指定區(qū)間之內(nèi)的元素都將被刪除。
14 RPOP key 移除并獲取列表最后一個(gè)元素
15 RPOPLPUSH source destination 移除列表的最后一個(gè)元素,并將該元素添加到另一個(gè)列表并返回
16 RPUSH key value1 [value2] 在列表中添加一個(gè)或多個(gè)值
17 RPUSHX key value 為已存在的列表添加值
示例:
127.0.0.1:6379[4]> LPUSH product:book redis (integer) 1 127.0.0.1:6379[4]> LPUSH product:book mongodb (integer) 2 127.0.0.1:6379[4]> LPUSH product:book mongodb in action (integer) 5 127.0.0.1:6379[4]> LPUSH product:book "mongodb in action" (integer) 6 // 長度 127.0.0.1:6379[4]> LLEN product:book (integer) 6 // index 從0開始,指定的大于列表其長度時(shí),獲取到最后的元素。 127.0.0.1:6379[4]> LRANGE product:book 0 7 1) "mongodb in action" 2) "action" 3) "in" 4) "mongodb" 5) "mongodb" 6) "redis"127.0.0.1:6379[4]> RPUSH product:book "spring in action" (integer) 7127.0.0.1:6379[4]> LRANGE product:book 0 10 1) "mongodb in action" 2) "action" 3) "in" 4) "mongodb" 5) "mongodb" 6) "redis" 7) "spring in action" // index: start from 0. 127.0.0.1:6379[4]> lset product:book 3 "what" OK127.0.0.1:6379[4]> LRANGE product:book 0 10 1) "mongodb in action" 2) "action" 3) "in" 4) "what" 5) "mongodb" 6) "redis" 7) "spring in action" // 127.0.0.1:6379[4]> RPOP product:book "spring in action"127.0.0.1:6379[4]> LRANGE product:book 0 10 1) "mongodb in action" 2) "action" 3) "in" 4) "what" 5) "mongodb" 6) "redis"127.0.0.1:6379[4]> LPOP product:book "mongodb in action" 127.0.0.1:6379[4]> LRANGE product:book 0 10 1) "action" 2) "in" 3) "what" 4) "mongodb" 5) "redis" 127.0.0.1:6379[4]> 127.0.0.1:6379[4]> LINDEX product:book 1 "in" 127.0.0.1:6379[4]> LRANGE product:book 0 10 1) "action" 2) "in" 3) "what" 4) "mongodb" 5) "redis" // 移除元素 -- value必須指定正確,否則,不會(huì)移除。 127.0.0.1:6379[4]> lrem product:book 2 "what" (integer) 1 127.0.0.1:6379[4]> LRANGE product:book 0 10 1) "action" 2) "in" 3) "mongodb" 4) "redis"Redis 集合(Set)
Redis的Set是string類型的無序集合。集合成員是唯一的,這就意味著集合中不能出現(xiàn)重復(fù)的數(shù)據(jù)。
Redis中集合是通過哈希表實(shí)現(xiàn)的,所以添加,刪除,查找的復(fù)雜度都是O(1)。
集合中最大的成員數(shù)為 2^32 - 1 (4294967295, 每個(gè)集合可存儲(chǔ)40多億個(gè)成員)。
Redis 集合命令
下表列出了 Redis 集合基本命令:集合的命令以S開頭,表示Set.
序號(hào) 命令及描述
1 SADD key member1 [member2] 向集合添加一個(gè)或多個(gè)成員
2 SCARD key 獲取集合的成員數(shù)
3 SDIFF key1 [key2] 返回給定所有集合的差集
4 SDIFFSTORE destination key1 [key2] 返回給定所有集合的差集并存儲(chǔ)在 destination 中
5 SINTER key1 [key2] 返回給定所有集合的交集
6 SINTERSTORE destination key1 [key2] 返回給定所有集合的交集并存儲(chǔ)在 destination 中
7 SISMEMBER key member 判斷 member 元素是否是集合 key 的成員
8 SMEMBERS key 返回集合中的所有成員
9 SMOVE source destination member 將 member 元素從 source 集合移動(dòng)到 destination 集合
10 SPOP key 移除并返回集合中的一個(gè)隨機(jī)元素
11 SRANDMEMBER key [count] 返回集合中一個(gè)或多個(gè)隨機(jī)數(shù)
12 SREM key member1 [member2] 移除集合中一個(gè)或多個(gè)成員
13 SUNION key1 [key2] 返回所有給定集合的并集
14 SUNIONSTORE destination key1 [key2] 所有給定集合的并集存儲(chǔ)在 destination 集合中
15 SSCAN key cursor [MATCH pattern] [COUNT count] 迭代集合中的元素
示例:
127.0.0.1:6379[4]> select 5 OK 127.0.0.1:6379[5]> dbsize (integer) 0 127.0.0.1:6379[5]> sadd product:set iphone (integer) 1 127.0.0.1:6379[5]> dbsize (integer) 1 127.0.0.1:6379[5]> sadd product:set nexus lumia (integer) 2 127.0.0.1:6379[5]> dbsize (integer) 1 127.0.0.1:6379[5]> SMEMBERS product:set 1) "iphone" 2) "lumia" 3) "nexus"127.0.0.1:6379[5]> sadd book:set "Spring in action" "redis in action" (integer) 2 127.0.0.1:6379[5]> SMEMBERS book:set 1) "redis in action" 2) "Spring in action" 127.0.0.1:6379[5]> SCARD (error) ERR wrong number of arguments for 'scard' command 127.0.0.1:6379[5]> SCARD product (integer) 0 127.0.0.1:6379[5]> SCARD product:book (integer) 0 127.0.0.1:6379[5]> SCARD product:set (integer) 3 127.0.0.1:6379[5]> SCARD book:set (integer) 2127.0.0.1:6379[5]> SUNION book:set product:set 1) "iphone" 2) "lumia" 3) "Spring in action" 4) "redis in action" 5) "nexus" 127.0.0.1:6379[5]> Sinter book:set product:set (empty list or set) 127.0.0.1:6379[5]> sadd book:set iphone (integer) 1 127.0.0.1:6379[5]> Sinter book:set product:set 1) "iphone" 127.0.0.1:6379[5]> SDIFF book:set product:set 1) "Spring in action" 2) "redis in action" 127.0.0.1:6379[5]> SDIFF product:set book:set 1) "nexus" 2) "lumia" 127.0.0.1:6379[5]> SDIFFSTORE product:other product:set book:set (integer) 2 127.0.0.1:6379[5]> SMEMBERS product:other 1) "nexus" 2) "lumia" 127.0.0.1:6379[5]> srem product:other nexus (integer) 1 127.0.0.1:6379[5]> SMEMBERS product:other 1) "lumia" 127.0.0.1:6379[5]> smembers book:set 1) "iphone" 2) "redis in action" 3) "Spring in action" 127.0.0.1:6379[5]> sadd book:set "redis in action" (integer) 0 127.0.0.1:6379[5]> smembers book:set 1) "iphone" 2) "redis in action" 3) "Spring in action" 127.0.0.1:6379[5]> smembers book:set 1) "iphone" 2) "redis in action" 3) "Spring in action"Redis 有序集合(sorted set)
Redis 有序集合和集合一樣也是string類型元素的集合,且不允許重復(fù)的成員。 集合是通過哈希表實(shí)現(xiàn)的,所以添加,刪除,查找的復(fù)雜度都是O(1)。 集合中最大的成員數(shù)為 2^32 - 1 (4294967295, 每個(gè)集合可存儲(chǔ)40多億個(gè)成員)。
不同的是每個(gè)元素都會(huì)關(guān)聯(lián)一個(gè)double類型的分?jǐn)?shù)。redis正是通過分?jǐn)?shù)來為集合中的成員進(jìn)行從小到大的排序。有序集合的成員是唯一的,但分?jǐn)?shù)(score)卻可以重復(fù)。
Redis 有序集合命令
下表列出了 redis 有序集合的基本命令,命令以Z開頭:
序號(hào) 命令及描述
1 ZADD key score1 member1 [score2 member2] 向有序集合添加一個(gè)或多個(gè)成員,或者更新已存在成員的分?jǐn)?shù)
2 ZCARD key 獲取有序集合的成員數(shù)
3 ZCOUNT key min max 計(jì)算在有序集合中指定區(qū)間分?jǐn)?shù)的成員數(shù)
4 ZINCRBY key increment member 有序集合中對指定成員的分?jǐn)?shù)加上增量 increment
5 ZINTERSTORE destination numkeys key [key …] 計(jì)算給定的一個(gè)或多個(gè)有序集的交集并將結(jié)果集存儲(chǔ)在新的有序集合 key 中
6 ZLEXCOUNT key min max 在有序集合中計(jì)算指定字典區(qū)間內(nèi)成員數(shù)量
7 ZRANGE key start stop [WITHSCORES] 通過索引區(qū)間返回有序集合成指定區(qū)間內(nèi)的成員
8 ZRANGEBYLEX key min max [LIMIT offset count] 通過字典區(qū)間返回有序集合的成員
9 ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT] 通過分?jǐn)?shù)返回有序集合指定區(qū)間內(nèi)的成員
10 ZRANK key member 返回有序集合中指定成員的索引
11 ZREM key member [member …] 移除有序集合中的一個(gè)或多個(gè)成員
12 ZREMRANGEBYLEX key min max 移除有序集合中給定的字典區(qū)間的所有成員
13 ZREMRANGEBYRANK key start stop 移除有序集合中給定的排名區(qū)間的所有成員
14 ZREMRANGEBYSCORE key min max 移除有序集合中給定的分?jǐn)?shù)區(qū)間的所有成員
15 ZREVRANGE key start stop [WITHSCORES] 返回有序集中指定區(qū)間內(nèi)的成員,通過索引,分?jǐn)?shù)從高到底
16 ZREVRANGEBYSCORE key max min [WITHSCORES] 返回有序集中指定分?jǐn)?shù)區(qū)間內(nèi)的成員,分?jǐn)?shù)從高到低排序
17 ZREVRANK key member 返回有序集合中指定成員的排名,有序集成員按分?jǐn)?shù)值遞減(從大到小)排序
18 ZSCORE key member 返回有序集中,成員的分?jǐn)?shù)值
19 ZUNIONSTORE destination numkeys key [key …] 計(jì)算給定的一個(gè)或多個(gè)有序集的并集,并存儲(chǔ)在新的 key 中
20 ZSCAN key cursor [MATCH pattern] [COUNT count] 迭代有序集合中的元素(包括元素成員和元素分值)
示例:
127.0.0.1:6379[6]> zadd product:major:lesson 1 java (integer) 1 127.0.0.1:6379[6]> dbsize (integer) 1 127.0.0.1:6379[6]> zadd product:major:lesson 2 mongodb (integer) 1 127.0.0.1:6379[6]> zadd product:major:lesson 3 redis (integer) 1 127.0.0.1:6379[6]> zadd product:major:lesson 4 mysql (integer) 1 127.0.0.1:6379[6]> dbsize (integer) 1127.0.0.1:6379[6]> ZRANGE product:major:lesson 0 10 1) "java" 2) "mongodb" 3) "redis" 4) "mysql"127.0.0.1:6379[6]> ZRANGE product:major:lesson 0 10 withscores 1) "java" 2) "1" 3) "mongodb" 4) "2" 5) "redis" 6) "3" 7) "mysql" 8) "4" // 127.0.0.1:6379[6]> ZRANGEBYSCOre product:major:lesson 1 4 1) "java" 2) "mongodb" 3) "redis" 4) "mysql" 127.0.0.1:6379[6]> ZRANGEBYSCOre product:major:lesson 2 4 1) "mongodb" 2) "redis" 3) "mysql"127.0.0.1:6379[6]> ZCARD product:major:lesson (integer) 4127.0.0.1:6379[6]> ZCARD product:major:lesson (integer) 4 127.0.0.1:6379[6]> ZCOUNT product:major:lesson 0 100 (integer) 4 127.0.0.1:6379[6]> ZCOUNT product:major:lesson 2 10 (integer) 3 // 返回zset指定member的score 127.0.0.1:6379[6]> ZSCORE product:major:lesson mysql "4" // 有序集合中指定成員的索引 -- start from 0. 127.0.0.1:6379[6]> ZRANK product:major:lesson mysql (integer) 3 // ZREVRange 127.0.0.1:6379[6]> ZREVRange product:major:lesson 2 4 1) "mongodb" 2) "java" 127.0.0.1:6379[6]> ZREVRange product:major:lesson 2 3 1) "mongodb" 2) "java" 127.0.0.1:6379[6]> ZREVRange product:major:lesson 0 1 1) "mysql" 2) "redis"telnet方式連接redis
telnet> open 127.0.0.1 6379 Trying 127.0.0.1... Connected to localhost. Escape character is '^]'. dbdize -ERR unknown command 'dbdize' dbsize :5 keys t* *3 $5 testb $5 testa $5 testckeys * *5 $5 testb $5 testa $6 intval $3 abc $5 testc shutdown Connection closed by foreign host.關(guān)閉服務(wù)
使用shutdown命令來關(guān)閉服務(wù)。
#關(guān)閉指定端口的redis-server $redis-cli -p 6380 shutdown或者在telnet連接后,輸入shutdown命令關(guān)閉服務(wù)。
總結(jié)
以上是生活随笔為你收集整理的NoSQL数据库Redis使用命令简介的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 微笑的眼泪
- 下一篇: 浪潮-存储双活解决方案研究