?
NOSQL的學(xué)習(xí)筆記:
1.最基本的命令
相信所有的NOSQL都會(huì)提供了命令:GET SET DEL?
--------------------------------------
redis 127.0.0.1:6379> set ee 10?
OK
redis 127.0.0.1:6379> get ee?
"10"
redis 127.0.0.1:6379> del ee ? ? ? ? ? ? ?// 返回值 1:代表正確 0:代表錯(cuò)誤
(integer) 1
redis 127.0.0.1:6379> get ee ?
(nil)
redis 127.0.0.1:6379>
--------------------------------------
?
del key1 key2 key3 ?//可刪除多個(gè)key
?
?
擴(kuò)展:
1.1 SETNX:設(shè)置一個(gè)值,如果不存在的話,已經(jīng)存在則不新增.對(duì)于SET的擴(kuò)展。
--------------------------------------
redis 127.0.0.1:6379> set ee 10?
OK
redis 127.0.0.1:6379> setnx ee 20?
(integer) 0
redis 127.0.0.1:6379> get ee ? ? ? ? ? ? // 因?yàn)橹按嬖趀e ?所以ee的值并沒(méi)有發(fā)生變化。
"10"
redis 127.0.0.1:6379> setnx aa 20 ? ? ? ?// ?aa 之前不存在,所以設(shè)置成功!
(integer) 1
redis 127.0.0.1:6379> get aa?
"20"
redis 127.0.0.1:6379>?
--------------------------------------
?
1.2 SETEX 設(shè)置過(guò)期時(shí)間,對(duì)于SET的擴(kuò)展。若是已經(jīng)存在,會(huì)覆蓋原來(lái)的值。
語(yǔ)法:
SETEX key seconds value
?
要求版本:>= 2.0.0
?
實(shí)踐:
--------------------------------------
redis 127.0.0.1:6379> setex ee 10 20?
OK
redis 127.0.0.1:6379> get ee?
"20"
redis 127.0.0.1:6379> ttl ee?
(integer) 4
redis 127.0.0.1:6379> ttl ee?
(integer) 2
redis 127.0.0.1:6379> ttl ee?
(integer) -1
redis 127.0.0.1:6379> get ee?
(nil)
redis 127.0.0.1:6379>?
--------------------------------------
?
限制:
等同于一下語(yǔ)句,不過(guò)是一個(gè)原子性的操作,很適合做緩存使用。
SET key value
EXPIRE key seconds ?# 設(shè)置生存時(shí)間
?
1.3 PSETEX ?對(duì)于 SETEX的再次擴(kuò)展,唯一的區(qū)別是以毫秒為單位,不是以秒為單位
語(yǔ)法:
PSETEX key milliseconds value
?
要求版本:>= 2.6.0
實(shí)踐:
--------------------------------------
redis 127.0.0.1:6379> setex ee 10 20?
OK
redis 127.0.0.1:6379> get ee?
"20"
redis 127.0.0.1:6379> ttl ee?
(integer) 4
redis 127.0.0.1:6379> ttl ee?
(integer) 2
redis 127.0.0.1:6379> ttl ee?
(integer) -1
redis 127.0.0.1:6379> get ee?
(nil)
redis 127.0.0.1:6379>?
--------------------------------------
?
1.4 MGET , MSET
獲取多個(gè)值或是設(shè)置多個(gè)值。
?
MSET :替換舊值,原子操作。
?
實(shí)踐:
--------------------------------------
redis 127.0.0.1:6379> mset key1 haha key2 hehe?
OK
redis 127.0.0.1:6379> mget key1 key2?
1) "haha"
2) "hehe"
redis 127.0.0.1:6379>?
--------------------------------------
?
1.5 MSETNX :設(shè)置多個(gè)key value,僅當(dāng)key存在時(shí) ?
MSETNX key value [key value ...]?
既然有setnx 就會(huì)有 這個(gè)命令
?
實(shí)踐:
--------------------------------------
redis 127.0.0.1:6379> msetnx key1 hehe key3 hoho ? ? ? ? ? ? ?//因?yàn)檫@是一個(gè)原子的操作,所以key1已經(jīng)存在,所以整體失敗了!
(integer) 0
redis 127.0.0.1:6379> mget key1 key2 key3 ? ? ? ? ? ? ? ? ? ? // 找不到所要的key3
1) "haha"
2) "hehe"
3) (nil)
redis 127.0.0.1:6379>?
--------------------------------------
?
1.6 GETSET
GETSET key value 設(shè)置一個(gè)key的value,并獲取設(shè)置前的值 。相當(dāng)于重置功能。
?
?
實(shí)踐:
--------------------------------------
redis 127.0.0.1:6379> incrby count 10?
(integer) 10
redis 127.0.0.1:6379> getset count "5" ? ?// 這個(gè)時(shí)候返回的是10,不是5
"10"
redis 127.0.0.1:6379> get count?
"5"
redis 127.0.0.1:6379>?
--------------------------------------
有時(shí)我們需要獲取計(jì)數(shù)器的值,并且自動(dòng)將其重置為0
?
1.7 GETRANGE 獲取存儲(chǔ)在一個(gè)關(guān)鍵的一個(gè)子字符串
?
實(shí)踐:
--------------------------------------
redis 127.0.0.1:6379> set longworld "hello world!"
OK
redis 127.0.0.1:6379> getrange ?longworld 0 5?
"hello "
redis 127.0.0.1:6379> getrange longworld -6 -1?
"world!"
redis 127.0.0.1:6379>?
redis 127.0.0.1:6379> getrange longworld 5 100 ? ? // 超出范圍的數(shù)據(jù)只取最后位
" world!"
--------------------------------------
?
1.8 SETRANGE 類似于GETRANGE 覆蓋在指定的偏移量開(kāi)始的關(guān)鍵字符串的一部分
?
實(shí)踐:
--------------------------------------
redis 127.0.0.1:6379> setrange longworld 6 "redis"
(integer) 12
redis 127.0.0.1:6379> get longworld?
"hello redis!"
redis 127.0.0.1:6379>?
--------------------------------------
?
1.9 STRLEN ?計(jì)算長(zhǎng)度
語(yǔ)法:
STRLEN key?
?
實(shí)踐:
--------------------------------------
redis 127.0.0.1:6379> strlen longworld?
(integer) 12
--------------------------------------
?
1.10 append 追加數(shù)據(jù) ,setrange是截取字符
語(yǔ)法:
append key str
?
實(shí)踐:
--------------------------------------
redis 127.0.0.1:6379> append longworld "!!!"
(integer) 15
redis 127.0.0.1:6379> get longworld?
"hello redis!!!!"
--------------------------------------
?
?
3.INCR :對(duì)于一個(gè)數(shù)值做遞增,步伐是1。
限制:
只允許對(duì)于數(shù)值類型做操作,若是字符串類型則報(bào)錯(cuò)。
?
是否線程安全:是的,是一個(gè)原子操作,不用擔(dān)心多線程并發(fā)修改同一個(gè)值得問(wèn)題。
即不會(huì)出現(xiàn)一下情況:
--------------------------------------
? ? Client A reads count as 10.
? ? Client B reads count as 10.
? ? Client A increments 10 and sets count to 11.
? ? Client B increments 10 and sets count to 11.
--------------------------------------
?
若是希望遞增的頻率不是1呢,那么使用INCRBY?
--------------------------------------
redis 127.0.0.1:6379> set ee 10?
OK
redis 127.0.0.1:6379> incrby ee 2 ? ? // 第三個(gè)參數(shù)是步頻
(integer) 12
redis 127.0.0.1:6379> get ee?
"12"
--------------------------------------
?
擴(kuò)展:
INCR &&INCRBY 對(duì)應(yīng)的命令是 DECR ,DECRBY
?
4.如何設(shè)置一個(gè)key的過(guò)期時(shí)間呢?
簡(jiǎn)單,通過(guò) EXPIRE來(lái)設(shè)置,通過(guò)TTL命令查看。
--------------------------------------
redis 127.0.0.1:6379> set ee 10
OK
redis 127.0.0.1:6379> expire ee 10 ? ? ? ? ?// 設(shè)置過(guò)期時(shí)間為10秒
(integer) 1
redis 127.0.0.1:6379> ttl ee
(integer) 8
redis 127.0.0.1:6379> ttl ee
(integer) 3
redis 127.0.0.1:6379> ttl ee ? ? ? ? ? ? ? ?// 已經(jīng)過(guò)期了。
(integer) -1
redis 127.0.0.1:6379> get ee ? ? ? ? ? ? ? ?// 已經(jīng)取不到值了 ?
(nil)
redis 127.0.0.1:6379> ? ? ? ? ? ? ? ? ?
--------------------------------------
?
若是不設(shè)置expire ,只是set 一個(gè)值后,再通過(guò)ttl 查看 返回結(jié)果是 -1 ,代表永遠(yuǎn)不過(guò)期。
--------------------------------------
redis 127.0.0.1:6379> set ee 10?
OK
redis 127.0.0.1:6379> ttl ee?
(integer) -1
redis 127.0.0.1:6379> get ee?
"10"
--------------------------------------
?
一個(gè)整體結(jié)構(gòu)圖:
圖太大 還是自己貼地址吧:
http://dl.iteye.com/upload/picture/pic/115893/840bfd7b-765e-3884-8253-0c7b3ec9db4c.jpg
?
?
已有 0 人發(fā)表留言,猛擊->>這里<<-參與討論
ITeye推薦