redis命令操作

redis命令操作

一、string类型的数据

1.插入、读取、删除一条string类型的数据
插入格式:set key value 
读取格式:get key
删除格式:del key

例子: set user "zhangsan"
      get user
      del user

2.string数据类型进行增减(前提是这条数据放value可以看成是数字)
格式:decr key     //减1
     incr key      //加1
    
    decrby key n //减n
    incrby key n //加n

例子:set id "10"
    decr id        //9
    incr id        //10
    decrby id 2 //8
    incrby id 3 //11 

3.一次性插入或者获取多条数据
插入多条数据格式:mset key1 value1 key2 value2 key3 value3......
获得多条数据格式:mget key1 key2 key3。。。

4.在插入一条string类型数据的同时为它指定一个存活期限
格式:setex key 时间 value        //时间默认单位是秒
例子:setex name 10 "zhangsan"  //name这条数据就只会存活10秒钟,过期会被redis自动清除

二、list数据类型(可以结合链表来理解)

redis命令操作_第1张图片
1.从头部插入数据(可以理解从链表的左插入)
格式:lpush  key  value1  value2  value3 

2.从尾部插入数据(可以理解为从链表的右边插入)
格式:rpush key  value1    value2    value3

3.读取list中指定范围的values
格式:lrange key 开始下标  结束下标
例子: lrang key 0 -1   //读取整个list,显示的顺序和你插入数据的顺序有关

4.从头部弹出一个元素
格式: lpop key

5.从尾部弹出一个元素
格式:rpop key
6.从一个list的尾部弹出一个元素插入到另一个list的头部
格式:rpoplpush key1 key2
例子:
localhost:6379> lrange list2 0 -1
1) "nidaye"
2) "buzhidao1jiao1shjenm"
3) "xiaoming"
4) "lihua"
localhost:6379> lpush list3 "1" "2" "3" "4" "5"
(integer) 5
localhost:6379> lrange list3 0 -1
1) "5"
2) "4"
3) "3"
4) "2"
5) "1"
localhost:6379> rpoplpush list2 list3
"lihua"
localhost:6379> lrange list3 0 -1
1) "lihua"
2) "5"
3) "4"
4) "3"
5) "2"
6) "1"
localhost:6379> lrange list2 0 -1
1) "nidaye"
2) "buzhidao1jiao1shjenm"
3) "xiaoming"

三、Hash数据结构

Redis中的Hashes类型可以看成具有String Key和String Value的map容器
redis命令操作_第2张图片

1.往redis库中插入一条hash类型的数据
格式: hset key field value
例子:
localhost:6379> hset jiage iphone7 6000
(integer) 1
localhost:6379> hset jiage meizu 1500
(integer) 1
localhost:6379> hset jiage xiaomi 2000
(integer) 1
localhost:6379> hset jiage huawei 3000
(integer) 1

在redis库中就形成了这样一条数据:
![](http://upload-images.jianshu.io/upload_images/3370369-d776eb929d1641ce.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

2.从redis库中获取一条hash类型数据的value
取出一条hash类型数据中所有field-value对
    格式:hgetall key
    例子:
    localhost:6379> hgetall jiage
    1) "iphone7"
    2) "6000"
    3) "meizu"
    4) "1500"
    5) "xiaomi"
    6) "2000"
    7) "huawei"
    8) "3000"

取出hash数据中所有fields
    格式:hkeys key
    例子:
    localhost:6379> hkeys jiage
    1) "iphone7"
    2) "meizu"
    3) "xiaomi"
    4) "huawei"

取出hash数据中一个指定field的值
    格式:hget key field
    例子:
    localhost:6379> hget jiage meizu
    "1500"

为hash数据中指定的一个field的值进行增减
    格式:hincrby key field n/-n
    例子:
    localhost:6379> hincrby jiage meizu 3000
    (integer) 4500

从hash数据中删除一个字段field及其值
    格式:hdel key field
    例子:
    localhost:6379> hgetall jiage
    1) "iphone7"
    2) "6000"
    3) "meizu"
    4) "4300"
    5) "xiaomi"
    6) "2000"
    7) "huawei"
    8) "3000"
    localhost:6379> hdel jiage xiaomi
    (integer) 1
    localhost:6379> hgetall jiage
    1) "iphone7"
    2) "6000"
    3) "meizu"
    4) "4300"
    5) "huawei"
    6) "3000"

四、Set数据结构功能

 集合的特点:无序、无重复元素
1.插入一条set数据
格式: sadd key value1 value2 value3。。。
例子;
localhost:6379> sadd name xiaohua zhaoliu wanwu liuxing
(integer) 4

2.获取一条set数据的所有members
格式:smembers key
例子:
localhost:6379> smembers name
1) "liuxing"
2) "wanwu"
3) "zhaoliu"
4) "xiaohua"

3.判断一个成员是否属于某条指定的set数据
格式:sismembers key value   //是返回1,不是返回0
例子:
localhost:6379> sismember name xiaohua
(integer) 1
localhost:6379> sismember name honghong
(integer) 0

4.求两个set数据的差集(差集 = 1 - 1和2的交集)
求差集
    格式:sdiff key1 key2  // key1 减去 (key1和key2的交集) 即: key1 - (key1 ∩ key2)
    例子:
    localhost:6379> sadd name xiaohua zhaoliu wanwu liuxing
    (integer) 4
    localhost:6379> sadd pepole xiaohua wanwu hahaha feifei furong
    (integer) 5
    localhost:6379> sdiff name pepole
    1) "liuxing"
    2) "zhaoliu"

求差集,并将结果存入到另一个set
    格式:sdiffstore  key1(保存差集)  key2  key3
    例子:
    localhost:6379> sdiffstore result name pepole
    (integer) 2
    localhost:6379> smembers result   //查看差集结果
    1) "liuxing"
    2) "zhaoliu"

求交集,求并集
    求交集
        格式:sinterstore key1(保存交集) key2 key3

    求并集
        格式:sunion key1 key2
        格式:sunionstore  key1(保存并集)  key2 key3

五、sortedSet(有序集合)数据结构

sortedset中存储的成员都有一个附带的分数值
而redis就可以根据分数来对成员进行各种排序(正序、倒序)

sortedSet存储示意图


redis命令操作_第3张图片

1.往redis库中插入一条sortedset数据
格式:zadd key 分数1 成员1 分数2 成员2 分数3 成员3。。。
例子:
localhost:6379> zadd yingixong 70 gailun 90 debang 60 yasuo
(integer) 3

2.从sortedset中查询有序结果
格式:zrange(正序)/zrevrange(倒序) key 开始下标 结束下标   // zrange key 0 -1 表示查看所有
例子:
    localhost:6379> zrange yingixong 0 2
    1) "yasuo"
    2) "gailun"
    3) "debang"
    localhost:6379> zrange yingixong 0 -1
    1) "yasuo"
    2) "gailun"
    3) "debang"


3.查询某个成员的名次
格式:zrank(正序)/zrevrank(倒序)  key 要查看的成员

4.修改成员的分数
格式:zincrby  key  分数(正数表示加,负数表示减)  成员
例子:
    给yasuo加5
        zincrby  yingixong 5 yasuo
    给gailun减10
        zincrby     yingixong -10 gailun

你可能感兴趣的:(redis命令操作)