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