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推荐