多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國(guó)內(nèi)最全I(xiàn)T社區(qū)平臺(tái) 聯(lián)系我們 | 收藏本站
阿里云優(yōu)惠2
您當(dāng)前位置:首頁(yè) > 數(shù)據(jù)庫(kù) > 數(shù)據(jù)庫(kù)應(yīng)用 > redis常用命令

redis常用命令

來(lái)源:程序員人生   發(fā)布時(shí)間:2016-07-01 09:05:55 閱讀次數(shù):3364次

[Redis] redis-cli 命令總結(jié)

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)


生活不易,碼農(nóng)辛苦
如果您覺(jué)得本網(wǎng)站對(duì)您的學(xué)習(xí)有所幫助,可以手機(jī)掃描二維碼進(jìn)行捐贈(zèng)
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關(guān)閉
程序員人生
主站蜘蛛池模板: 欧美多人 | 操白嫩| 在线a级 | www.亚洲精品 | 可以看的黄色网址 | 日韩欧美一区二区三区不卡在线 | 国产福利网站 | 免费18岁禁看 | 91精品久久久久久久久网影视 | 国产啪视频1000部免费视频 | 国产片在线观看 | 被两个男人吃奶添下面视频 | 一级毛片在线免费观看 | 国产免费网站看v片元遮挡 国产免费午夜a无码v视频 | 激情欧美成人久久综合小说 | 在线亚洲国产精品区 | xxx久久| 久久天天躁狠狠躁夜夜2020一 | 日本综合欧美一区二区三区 | 精品国产精品 | 亚洲 欧美 精品 | 国产成人精品天堂 | 有色视频在线观看免费高清 | 久草在线资源福利站 | 日本中文在线 | 欧美日韩国产超高清免费看片 | 欧美在线性 | 日韩欧美视频一区二区在线观看 | 久草成人网| www一区| 亚洲精品第1页 | 手机在线日韩高清理论片 | 精品推荐国产麻豆剧传媒 | 一本之道无吗一二三区 | 伊人官网| 亚洲97在线| 欧美成人黄色小说 | 欧美在线一级视频 | 伊人色婷婷 | 高清完整视频在线播放 | 亚洲国产成人精品不卡青青草原 |