?
NOSQL的學習筆記:
1.最基本的命令
相信所有的NOSQL都會提供了命令: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:代表錯誤
(integer) 1
redis 127.0.0.1:6379> get ee ?
(nil)
redis 127.0.0.1:6379>
--------------------------------------
?
del key1 key2 key3 ?//可刪除多個key
?
?
擴展:
1.1 SETNX:設置一個值,如果不存在的話,已經存在則不新增.對于SET的擴展。
--------------------------------------
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 ? ? ? ? ? ? // 因為之前存在ee ?所以ee的值并沒有發生變化。
"10"
redis 127.0.0.1:6379> setnx aa 20 ? ? ? ?// ?aa 之前不存在,所以設置成功!
(integer) 1
redis 127.0.0.1:6379> get aa?
"20"
redis 127.0.0.1:6379>?
--------------------------------------
?
1.2 SETEX 設置過期時間,對于SET的擴展。若是已經存在,會覆蓋原來的值。
語法:
SETEX key seconds value
?
要求版本:>= 2.0.0
?
實踐:
--------------------------------------
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>?
--------------------------------------
?
限制:
等同于一下語句,不過是一個原子性的操作,很適合做緩存使用。
SET key value
EXPIRE key seconds ?# 設置生存時間
?
1.3 PSETEX ?對于 SETEX的再次擴展,唯一的區別是以毫秒為單位,不是以秒為單位
語法:
PSETEX key milliseconds value
?
要求版本:>= 2.6.0
實踐:
--------------------------------------
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
獲取多個值或是設置多個值。
?
MSET :替換舊值,原子操作。
?
實踐:
--------------------------------------
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 :設置多個key value,僅當key存在時 ?
MSETNX key value [key value ...]?
既然有setnx 就會有 這個命令
?
實踐:
--------------------------------------
redis 127.0.0.1:6379> msetnx key1 hehe key3 hoho ? ? ? ? ? ? ?//因為這是一個原子的操作,所以key1已經存在,所以整體失敗了!
(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 設置一個key的value,并獲取設置前的值 。相當于重置功能。
?
?
實踐:
--------------------------------------
redis 127.0.0.1:6379> incrby count 10?
(integer) 10
redis 127.0.0.1:6379> getset count "5" ? ?// 這個時候返回的是10,不是5
"10"
redis 127.0.0.1:6379> get count?
"5"
redis 127.0.0.1:6379>?
--------------------------------------
有時我們需要獲取計數器的值,并且自動將其重置為0
?
1.7 GETRANGE 獲取存儲在一個關鍵的一個子字符串
?
實踐:
--------------------------------------
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 ? ? // 超出范圍的數據只取最后位
" world!"
--------------------------------------
?
1.8 SETRANGE 類似于GETRANGE 覆蓋在指定的偏移量開始的關鍵字符串的一部分
?
實踐:
--------------------------------------
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 ?計算長度
語法:
STRLEN key?
?
實踐:
--------------------------------------
redis 127.0.0.1:6379> strlen longworld?
(integer) 12
--------------------------------------
?
1.10 append 追加數據 ,setrange是截取字符
語法:
append key str
?
實踐:
--------------------------------------
redis 127.0.0.1:6379> append longworld "!!!"
(integer) 15
redis 127.0.0.1:6379> get longworld?
"hello redis!!!!"
--------------------------------------
?
?
3.INCR :對于一個數值做遞增,步伐是1。
限制:
只允許對于數值類型做操作,若是字符串類型則報錯。
?
是否線程安全:是的,是一個原子操作,不用擔心多線程并發修改同一個值得問題。
即不會出現一下情況:
--------------------------------------
? ? 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 ? ? // 第三個參數是步頻
(integer) 12
redis 127.0.0.1:6379> get ee?
"12"
--------------------------------------
?
擴展:
INCR &&INCRBY 對應的命令是 DECR ,DECRBY
?
4.如何設置一個key的過期時間呢?
簡單,通過 EXPIRE來設置,通過TTL命令查看。
--------------------------------------
redis 127.0.0.1:6379> set ee 10
OK
redis 127.0.0.1:6379> expire ee 10 ? ? ? ? ?// 設置過期時間為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 ? ? ? ? ? ? ? ?// 已經過期了。
(integer) -1
redis 127.0.0.1:6379> get ee ? ? ? ? ? ? ? ?// 已經取不到值了 ?
(nil)
redis 127.0.0.1:6379> ? ? ? ? ? ? ? ? ?
--------------------------------------
?
若是不設置expire ,只是set 一個值后,再通過ttl 查看 返回結果是 -1 ,代表永遠不過期。
--------------------------------------
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"
--------------------------------------
?
一個整體結構圖:
圖太大 還是自己貼地址吧:
http://dl.iteye.com/upload/picture/pic/115893/840bfd7b-765e-3884-8253-0c7b3ec9db4c.jpg
?
?
已有 0 人發表留言,猛擊->>這里<<-參與討論
ITeye推薦