Redis提供了豐富的命令(command)對(duì)數(shù)據(jù)庫(kù)和各種數(shù)據(jù)類型進(jìn)行操作,這些command可以在Linux終端使用。
在編程時(shí),比如使用Redis 的Java語(yǔ)言包,這些命令都有對(duì)應(yīng)的方法。下面將Redis提供的命令做1總結(jié)。
官網(wǎng)命令列表:http://redis.io/commands (英文)
1、連接操作相干的命令
quit:關(guān)閉連接(connection)
auth:簡(jiǎn)單密碼認(rèn)證
2、對(duì)value操作的命令
exists(key):確認(rèn)1個(gè)key是不是存在
del(key):刪除1個(gè)key
type(key):返回值的類型
keys(pattern):返回滿足給定pattern的所有key
randomkey:隨機(jī)返回key空間的1個(gè)key
rename(oldname, newname):將key由oldname重命名為newname,若newname存在則刪除newname表示的key
dbsize:返回當(dāng)前數(shù)據(jù)庫(kù)中key的數(shù)目
expire:設(shè)定1個(gè)key的活動(dòng)時(shí)間(s)
ttl:取得1個(gè)key的活動(dòng)時(shí)間
select(index):按索引查詢
move(key, dbindex):將當(dāng)前數(shù)據(jù)庫(kù)中的key轉(zhuǎn)移到有dbindex索引的數(shù)據(jù)庫(kù)
flushdb:刪除當(dāng)前選擇數(shù)據(jù)庫(kù)中的所有key
flushall:刪除所有數(shù)據(jù)庫(kù)中的所有key
3、對(duì)String操作的命令
set(key, value):給數(shù)據(jù)庫(kù)中名稱為key的string賦予值value
get(key):返回數(shù)據(jù)庫(kù)中名稱為key的string的value
getset(key, value):給名稱為key的string賦予上1次的value
mget(key1, key2,…, key N):返回庫(kù)中多個(gè)string(它們的名稱為key1,key2…)的value
setnx(key, value):如果不存在名稱為key的string,則向庫(kù)中添加string,名稱為key,值為value
setex(key, time, value):向庫(kù)中添加string(名稱為key,值為value)同時(shí),設(shè)定過(guò)期時(shí)間time
mset(key1, value1, key2, value2,…key N, value N):同時(shí)給多個(gè)string賦值,名稱為key i的string賦值value i
msetnx(key1, value1, key2, value2,…key N, value N):如果所著名稱為key i的string都不存在,則向庫(kù)中添加string,
名稱key i賦值為value i
incr(key):名稱為key的string增1操作
incrby(key, integer):名稱為key的string增加integer
decr(key):名稱為key的string減1操作
decrby(key, integer):名稱為key的string減少integer
append(key, value):名稱為key的string的值附加value
substr(key, start, end):返回名稱為key的string的value的子串
4、對(duì)List操作的命令
rpush(key, value):在名稱為key的list尾添加1個(gè)值為value的元素
lpush(key, value):在名稱為key的list頭添加1個(gè)值為value的 元素
llen(key):返回名稱為key的list的長(zhǎng)度
lrange(key, start, end):返回名稱為key的list中start至end之間的元素(下標(biāo)從0開(kāi)始,下同)
ltrim(key, start, end):截取名稱為key的list,保存start至end之間的元素
lindex(key, index):返回名稱為key的list中index位置的元素
lset(key, index, value):給名稱為key的list中index位置的元素賦值為value
lrem(key, count, value):刪除count個(gè)名稱為key的list中值為value的元素。
count為0,刪除所有值為value的元素,count>0從頭至尾刪除count個(gè)值為value的元素,count<0從尾到頭刪除|count|個(gè)值為value的元素。
lpop(key):返回并刪除名稱為key的list中的首元素 rpop(key):返回并刪除名稱為key的list中的尾元素
blpop(key1, key2,… key N, timeout):lpop命令的block版本。
即當(dāng)timeout為0時(shí),若遇到名稱為key i的list不存在或該list為空,則命令結(jié)束。
如果timeout>0,則遇到上述情況時(shí),等待timeout秒,如果問(wèn)題沒(méi)有解決,則對(duì)keyi+1開(kāi)始的list履行pop操作。
brpop(key1, key2,… key N, timeout):rpop的block版本。參考上1命令。
rpoplpush(srckey, dstkey):返回并刪除名稱為srckey的list的尾元素,并將該元素添加到名稱為dstkey的list的頭部
5、對(duì)Set操作的命令
sadd(key, member):向名稱為key的set中添加元素member
srem(key, member) :刪除名稱為key的set中的元素member
spop(key) :隨機(jī)返回并刪除名稱為key的set中1個(gè)元素
smove(srckey, dstkey, member) :將member元素從名稱為srckey的集合移到名稱為dstkey的集合
scard(key) :返回名稱為key的set的基數(shù)
sismember(key, member) :測(cè)試member是不是是名稱為key的set的元素
sinter(key1, key2,…key N) :求交集
sinterstore(dstkey, key1, key2,…key N) :求交集并將交集保存到dstkey的集合
sunion(key1, key2,…key N) :求并集
sunionstore(dstkey, key1, key2,…key N) :求并集并將并集保存到dstkey的集合
sdiff(key1, key2,…key N) :求差集
sdiffstore(dstkey, key1, key2,…key N) :求差集并將差集保存到dstkey的集合
smembers(key) :返回名稱為key的set的所有元素
srandmember(key) :隨機(jī)返回名稱為key的set的1個(gè)元素
6、對(duì)zset(sorted set)操作的命令
zadd(key, score, member):向名稱為key的zset中添加元素member,score用于排序。如果該元素已存在,則根據(jù)score更新該元素的順序。
zrem(key, member) :刪除名稱為key的zset中的元素member
zincrby(key, increment, member) :如果在名稱為key的zset中已存在元素member,則該元素的score增加increment;
否則向集合中添加該元素,其score的值為increment
zrank(key, member) :返回名稱為key的zset(元素已按score從小到大排序)中member元素的rank(即index,從0開(kāi)始),
若沒(méi)有member元素,返回“nil”
zrevrank(key, member) :返回名稱為key的zset(元素已按score從大到小排序)中member元素的rank(即index,從0開(kāi)始),
若沒(méi)有member元素,返回“nil”
zrange(key, start, end):返回名稱為key的zset(元素已按score從小到大排序)中的index從start到end的所有元素
zrevrange(key, start, end):返回名稱為key的zset(元素已按score從大到小排序)中的index從start到end的所有元素
zrangebyscore(key, min, max):返回名稱為key的zset中score >= min且score <= max的所有元素
zcard(key):返回名稱為key的zset的基數(shù) zscore(key, element):返回名稱為key的zset中元素element的
score zremrangebyrank(key, min, max):刪除名稱為key的zset中rank >= min且rank <= max的所有元素
zremrangebyscore(key, min, max) :刪除名稱為key的zset中score >= min且score <= max的所有元素
zunionstore / zinterstore(dstkeyN, key1,…,keyN, WEIGHTS w1,…wN, AGGREGATE SUM|MIN|MAX):對(duì)N個(gè)zset求并集和交集,
并將最后的集合保存在dstkeyN中。對(duì)集合中每個(gè)元素的score,在進(jìn)行AGGREGATE運(yùn)算前,都要乘以對(duì)的WEIGHT參數(shù)。
如果沒(méi)有提供WEIGHT,默許為1。默許的AGGREGATE是SUM,即結(jié)果集合中元素的score是所有集合對(duì)應(yīng)元素進(jìn)行SUM運(yùn)算的值,而MIN和MAX是指,
結(jié)果集合中元素的score是所有集合對(duì)應(yīng)元素中最小值和最大值。
7、對(duì)Hash操作的命令
hset(key, field, value):向名稱為key的hash中添加元素field<—>value
hget(key, field):返回名稱為key的hash中field對(duì)應(yīng)的value
hmget(key, field1, …,field N):返回名稱為key的hash中field i對(duì)應(yīng)的value
hmset(key, field1, value1,…,field N, value N):向名稱為key的hash中添加元素field i<—>value i
hincrby(key, field, integer):將名稱為key的hash中field的value增加integer
hexists(key, field):名稱為key的hash中是不是存在鍵為field的域
hdel(key, field):刪除名稱為key的hash中鍵為field的域
hlen(key):返回名稱為key的hash中元素個(gè)數(shù)
hkeys(key):返回名稱為key的hash中所有鍵
hvals(key):返回名稱為key的hash中所有鍵對(duì)應(yīng)的value
hgetall(key):返回名稱為key的hash中所有的鍵(field)及其對(duì)應(yīng)的value
8、持久化
save:將數(shù)據(jù)同步保存到磁盤
bgsave:將數(shù)據(jù)異步保存到磁盤
lastsave:返回上次成功將數(shù)據(jù)保存到磁盤的Unix時(shí)戳
shundown:將數(shù)據(jù)同步保存到磁盤,然后關(guān)閉服務(wù)
9、遠(yuǎn)程服務(wù)控制
info:提供服務(wù)器的信息和統(tǒng)計(jì)
monitor:實(shí)時(shí)轉(zhuǎn)儲(chǔ)收到的要求
slaveof:改變復(fù)制策略設(shè)置
config:在運(yùn)行時(shí)配置Redis服務(wù)器
1、概述:
在該系列的前幾篇博客中,主要講述的是與Redis數(shù)據(jù)類型相干的命令,如String、List、Set、Hashes和Sorted-Set。這些命令都具有1個(gè)共同點(diǎn),即所有的操作都是針對(duì)與Key關(guān)聯(lián)的Value的。而該篇博客將主要講述與Key相干的Redis命令。學(xué)習(xí)這些命令對(duì)學(xué)習(xí)Redis是非常重要的基礎(chǔ),也是能夠充分發(fā)掘Redis潛力的利器。
在該篇博客中,我們將1如既往的給出所有相干命令的明細(xì)列表和典型示例,以便于我們現(xiàn)在的學(xué)習(xí)和今后的查閱。
2、相干命令列表:
命令原型 | 時(shí)間復(fù)雜度 | 命令描寫 | 返回值 |
KEYS pattern | O(N) | 時(shí)間復(fù)雜度中的N表示數(shù)據(jù)庫(kù)中Key的數(shù)量。獲得所有匹配pattern參數(shù)的Keys。需要說(shuō)明的是,在我們的正常操作中應(yīng)當(dāng)盡可能避免對(duì)該命令的調(diào)用,由于對(duì)大型數(shù)據(jù)庫(kù)而言,該命令是非常耗時(shí)的,對(duì)Redis服務(wù)器的性能打擊也是比較大的。pattern支持glob-style的通配符格式,如*表示任意1個(gè)或多個(gè)字符,?表示任意字符,[abc]表示方括號(hào)中任意1個(gè)字母。 | 匹配模式的鍵列表。 |
DEL key [key ...] | O(N) | 時(shí)間復(fù)雜度中的N表示刪除的Key數(shù)量。從數(shù)據(jù)庫(kù)刪除中參數(shù)中指定的keys,如果指定鍵不存在,則直接疏忽。還需要另行指出的是,如果指定的Key關(guān)聯(lián)的數(shù)據(jù)類型不是String類型,而是List、Set、Hashes和Sorted Set等容器類型,該命令刪除每一個(gè)鍵的時(shí)間復(fù)雜度為O(M),其中M表示容器中元素的數(shù)量。而對(duì)String類型的Key,其時(shí)間復(fù)雜度為O(1)。 | 實(shí)際被刪除的Key數(shù)量。 |
EXISTS key | O(1) | 判斷指定鍵是不是存在。 | 1表示存在,0表示不存在。 |
MOVE key db | O(1) | 將當(dāng)前數(shù)據(jù)庫(kù)中指定的鍵Key移動(dòng)到參數(shù)中指定的數(shù)據(jù)庫(kù)中。如果該Key在目標(biāo)數(shù)據(jù)庫(kù)中已存在,或在當(dāng)前數(shù)據(jù)庫(kù)中其實(shí)不存在,該命令將不做任何操作并返回0。 | 移動(dòng)成功返回1,否則0。 |
RENAME key newkey | O(1) | 為指定指定的鍵重新命名,如果參數(shù)中的兩個(gè)Keys的命令相同,或是源Key不存在,該命令都會(huì)返回相干的毛病信息。如果newKey已存在,則直接覆蓋。 | |
RENAMENX key newkey | O(1) | 如果新值不存在,則將參數(shù)中的原值修改成新值。其它條件和RENAME1致。 | 1表示修改成功,否則0。 |
PERSIST key | O(1) | 如果Key存在過(guò)期時(shí)間,該命令會(huì)將其過(guò)期時(shí)間消除,使該Key不再有超時(shí),而是可以持久化存儲(chǔ)。 | 1表示Key的過(guò)期時(shí)間被移出,0表示該Key不存在或沒(méi)有過(guò)期時(shí)間。 |
EXPIRE key seconds | O(1) | 該命令為參數(shù)中指定的Key設(shè)定超時(shí)的秒數(shù),在超過(guò)該時(shí)間后,Key被自動(dòng)的刪除。如果該Key在超時(shí)之前被修改,與該鍵關(guān)聯(lián)的超時(shí)將被移除。 | 1表示超時(shí)被設(shè)置,0則表示Key不存在,或不能被設(shè)置。 |
EXPIREAT key timestamp | O(1) | 該命令的邏輯功能和EXPIRE完全相同,唯1的差別是該命令指定的超時(shí)時(shí)間是絕對(duì)時(shí)間,而不是相對(duì)時(shí)間。該時(shí)間參數(shù)是Unix timestamp格式的,即從1970年1月1日開(kāi)始所流經(jīng)的秒數(shù)。 | 1表示超時(shí)被設(shè)置,0則表示Key不存在,或不能被設(shè)置。 |
TTL key | O(1) | 獲得該鍵所剩的超時(shí)描寫。 | 返回所剩描寫,如果該鍵不存在或沒(méi)有超時(shí)設(shè)置,則返回⑴。 |
RANDOMKEY | O(1) | 從當(dāng)前打開(kāi)的數(shù)據(jù)庫(kù)中隨機(jī)的返回1個(gè)Key。 | 返回的隨機(jī)鍵,如果該數(shù)據(jù)庫(kù)是空的則返回nil。 |
TYPE key | O(1) | 獲得與參數(shù)中指定鍵關(guān)聯(lián)值的類型,該命令將以字符串的格式返回。 | 返回的字符串為string、list、set、hash和zset,如果key不存在返回none。 |
SORT key [BY pattern] [LIMIT offset count] [GET pattern [GET pattern ...]] [ASC|DESC] [ALPHA] [STORE destination] | O(N+M*log(M)) | 這個(gè)命令相對(duì)來(lái)講是比較復(fù)雜的,因此我們這里只是給出最基本的用法,有興趣的網(wǎng)友可以去參考redis的官方文檔。 | 返回排序后的原始列表。 |
3、命令示例:
1. KEYS/RENAME/DEL/EXISTS/MOVE/RENAMENX:
#在Shell命令行下啟動(dòng)Redis客戶端工具。
/> redis-cli
#清空當(dāng)前選擇的數(shù)據(jù)庫(kù),以便于對(duì)后面示例的理解。
redis 127.0.0.1:6379> flushdb
OK
#添加String類型的摹擬數(shù)據(jù)。
redis 127.0.0.1:6379> set mykey 2
OK
redis 127.0.0.1:6379> set mykey2 "hello"
OK
#添加Set類型的摹擬數(shù)據(jù)。
redis 127.0.0.1:6379> sadd mysetkey 1 2 3
(integer) 3
#添加Hash類型的摹擬數(shù)據(jù)。
redis 127.0.0.1:6379> hset mmtest username "stephen"
(integer) 1
#根據(jù)參數(shù)中的模式,獲得當(dāng)前數(shù)據(jù)庫(kù)中符合該模式的所有key,從輸出可以看出,該命令在履行時(shí)其實(shí)不辨別與Key關(guān)聯(lián)的Value類型。
redis 127.0.0.1:6379> keys my*
1) "mysetkey"
2) "mykey"
3) "mykey2"
#刪除兩個(gè)Keys。
redis 127.0.0.1:6379> del mykey mykey2
(integer) 2
#查看1下剛剛刪除的Key是不是還存在,從返回結(jié)果看,mykey確切已刪除。
redis 127.0.0.1:6379> exists mykey
(integer) 0
#查看1下沒(méi)有刪除的Key,以和上面的命令結(jié)果進(jìn)行比較。
redis 127.0.0.1:6379> exists mysetkey
(integer) 1
#將當(dāng)前數(shù)據(jù)庫(kù)中的mysetkey鍵移入到ID為1的數(shù)據(jù)庫(kù)中,從結(jié)果可以看出已移動(dòng)成功。
redis 127.0.0.1:6379> move mysetkey 1
(integer) 1
#打開(kāi)ID為1的數(shù)據(jù)庫(kù)。
redis 127.0.0.1:6379> select 1
OK
#查看1下剛剛移動(dòng)過(guò)來(lái)的Key是不是存在,從返回結(jié)果看已存在了。
redis 127.0.0.1:6379[1]> exists mysetkey
(integer) 1
#在重新打開(kāi)ID為0的缺省數(shù)據(jù)庫(kù)。
redis 127.0.0.1:6379[1]> select 0
OK
#查看1下剛剛移走的Key是不是已不存在,從返回結(jié)果看已移走。
redis 127.0.0.1:6379> exists mysetkey
(integer) 0
#準(zhǔn)備新的測(cè)試數(shù)據(jù)。
redis 127.0.0.1:6379> set mykey "hello"
OK
#將mykey改名為mykey1
redis 127.0.0.1:6379> rename mykey mykey1
OK
#由于mykey已被重新命名,再次獲得將返回nil。
redis 127.0.0.1:6379> get mykey
(nil)
#通過(guò)新的鍵名獲得。
redis 127.0.0.1:6379> get mykey1
"hello"
#由于mykey已不存在了,所以返回毛病信息。
redis 127.0.0.1:6379> rename mykey mykey1
(error) ERR no such key
#為renamenx準(zhǔn)備測(cè)試key
redis 127.0.0.1:6379> set oldkey "hello"
OK
redis 127.0.0.1:6379> set newkey "world"
OK
#由于newkey已存在,因此該命令未能成功履行。
redis 127.0.0.1:6379> renamenx oldkey newkey
(integer) 0
#查看newkey的值,發(fā)現(xiàn)它也沒(méi)有被renamenx覆蓋。
redis 127.0.0.1:6379> get newkey
"world"
2. PERSIST/EXPIRE/EXPIREAT/TTL:
#為后面的示例準(zhǔn)備的測(cè)試數(shù)據(jù)。
redis 127.0.0.1:6379> set mykey "hello"
OK
#將該鍵的超時(shí)設(shè)置為100秒。
redis 127.0.0.1:6379> expire mykey 100
(integer) 1
#通過(guò)ttl命令查看1下還剩下多少秒。
redis 127.0.0.1:6379> ttl mykey
(integer) 97
#立刻履行persist命令,該存在超時(shí)的鍵變成持久化的鍵,行將該Key的超時(shí)去掉。
redis 127.0.0.1:6379> persist mykey
(integer) 1
#ttl的返回值告知我們,該鍵已沒(méi)有超時(shí)了。
redis 127.0.0.1:6379> ttl mykey
(integer) ⑴
#為后面的expire命令準(zhǔn)備數(shù)據(jù)。
redis 127.0.0.1:6379> del mykey
(integer) 1
redis 127.0.0.1:6379> set mykey "hello"
OK
#設(shè)置該鍵的超時(shí)被100秒。
redis 127.0.0.1:6379> expire mykey 100
(integer) 1
#用ttl命令看1下當(dāng)前還剩下多少秒,從結(jié)果中可以看出還剩下96秒。
redis 127.0.0.1:6379> ttl mykey
(integer) 96
#重新更新該鍵的超時(shí)時(shí)間為20秒,從返回值可以看出該命令履行成功。
redis 127.0.0.1:6379> expire mykey 20
(integer) 1
#再用ttl確認(rèn)1下,從結(jié)果中可以看出果然被更新了。
redis 127.0.0.1:6379> ttl mykey
(integer) 17
#立刻更新該鍵的值,以使其超時(shí)無(wú)效。
redis 127.0.0.1:6379> set mykey "world"
OK
#從ttl的結(jié)果可以看出,在上1條修改該鍵的命令履行后,該鍵的超時(shí)也無(wú)效了。
redis 127.0.0.1:6379> ttl mykey
(integer) ⑴
3. TYPE/RANDOMKEY/SORT:
#由于mm鍵在數(shù)據(jù)庫(kù)中不存在,因此該命令返回none。
redis 127.0.0.1:6379> type mm
none
#mykey的值是字符串類型,因此返回string。
redis 127.0.0.1:6379> type mykey
string
#準(zhǔn)備1個(gè)值是set類型的鍵。
redis 127.0.0.1:6379> sadd mysetkey 1 2
(integer) 2
#mysetkey的鍵是set,因此返回字符串set。
redis 127.0.0.1:6379> type mysetkey
set
#返回數(shù)據(jù)庫(kù)中的任意鍵。
redis 127.0.0.1:6379> randomkey
"oldkey"
#清空當(dāng)前打開(kāi)的數(shù)據(jù)庫(kù)。
redis 127.0.0.1:6379> flushdb
OK
#由于沒(méi)有數(shù)據(jù)了,因此返回nil。
redis 127.0.0.1:6379> randomkey
(nil)