Linux我爱编程

03_Redis数据类型和数据操作的命令

2017-04-20  本文已影响202人  对方不想理你并向你抛出一个异常

redis主题

01_Redis介绍和安装运行
02_Jedis的介绍和使用
03_Redis数据类型和数据操作的命令
04_Redis集群

01-string字符串

介绍
  redis中没有使用C语言的字符串表示,而是自定义一个数据结构叫SDS(simple dynamic string)即简单动态字符串。
  打开下载的redis源码包,找到src下的sds.h文件查看sds源码:

struct sdshdr {
    //字符串长度
    unsigned int len;
    //buf数组中未使用的字节数量
    unsigned int free;
    //用于保存字符串
    char buf[];
};

c语言对字符串的存储是使用字符数组,遇到'\0'字符则认为字符串结束,redis的字符串可以存储任何类型的数据,因为任何类型数据都可以表示成二进制,sds结构中的char buf[]就是存储了二进制数据。
  redis的字符串是二进制安全的,什么是二进制安全?简单理解就是存入什么数据取出的还是什么数据。redis中的sds不像c语言处理字符串那样遇到'\0'字符则认证字符串结束,它不会对存储进去的二进制数据进行处理,存入什么数据取出还是什么数据。

命令

127.0.0.1:6379> set str1 nihao
OK
127.0.0.1:6379> get str1
"nihao"

当键不存在时返回空结果。
GETSET key value
取值时同时对key进行赋值操作。

127.0.0.1:6379> del str1
(integer) 1
127.0.0.1:6379> get str1
(nil)
127.0.0.1:6379> incr num
(integer) 1
127.0.0.1:6379> incr num
(integer) 2
127.0.0.1:6379> incr num
(integer) 3
127.0.0.1:6379> incrby num 2
(integer) 5
127.0.0.1:6379> incrby num 3
(integer) 8
127.0.0.1:6379> get num
"8"
127.0.0.1:6379> decr num
(integer) 7
127.0.0.1:6379> decrby num 2
(integer) 5
127.0.0.1:6379> decrby num 3
(integer) 2
127.0.0.1:6379> get num
"2"
127.0.0.1:6379> set str1 hello
OK
127.0.0.1:6379> append str1 " world!"
(integer) 12
127.0.0.1:6379> get str1
"hello world!"
127.0.0.1:6379> strlen str1
(integer) 12
127.0.0.1:6379> strlen str11
(integer) 0
127.0.0.1:6379> mset k1 v1 k2 v2 k3 v3
OK
127.0.0.1:6379> get k1
"v1"
127.0.0.1:6379> get k2
"v2"
127.0.0.1:6379> mget k2 k3
1) "v2"
2) "v3"

应用

127.0.0.1:6379> INCR items:id
(integer) 2
127.0.0.1:6379> INCR items:id
(integer) 3

java代码参考测试工程。

02-hash散列

127.0.0.1:6379> hset user username zhangsan 
(integer) 1

HMSET key field value [field value ...] 一次可以设置多个字段值

127.0.0.1:6379> hmset user age 20 username lisi 
OK
127.0.0.1:6379> hget user username
"zhangsan"

HMGET key field [field ...] 一次可以获取多个字段值

127.0.0.1:6379> hmget user age username
1) "20"
2) "lisi"

HGETALL key

127.0.0.1:6379> hgetall user
1) "age"
2) "20"
3) "username"
4) "lisi"

HSET命令不区分插入和更新操作,当执行插入操作时HSET命令返回1,当执行更新操作时返回0.

127.0.0.1:6379> hdel user age
(integer) 1
127.0.0.1:6379> hdel user age name
(integer) 0
127.0.0.1:6379> hdel user age username
(integer) 1 
127.0.0.1:6379> hincrby user age 2  将用户的年龄加2
(integer) 22
127.0.0.1:6379> hget user age       获取用户的年龄
"22“
127.0.0.1:6379> hexists user age        查看user中是否有age字段
(integer) 1
127.0.0.1:6379> hexists user name   查看user中是否有name字段
(integer) 0

HSETNX key field value
当字段不存在时赋值,类似HSET,区别在于如果字段已经存在,该命令不执行任何操作。

127.0.0.1:6379> hsetnx user age 30  如果user中没有age字段则设置age值为30,否则不做任何操作
(integer) 0

②只获取字段名或字段值
HKEYS key
HVALS key

127.0.0.1:6379> hmset user age 20 name lisi 
OK
127.0.0.1:6379> hkeys user
1) "age"
2) "name"
127.0.0.1:6379> hvals user
1) "20"
2) "lisi"

③获取字段数量
HLEN key

127.0.0.1:6379> hlen user
(integer) 2
127.0.0.1:6379> HMSET items:1001 id 3 name apple price 999.9
OK

获取商品信息

127.0.0.1:6379> HGET items:1001 id
"3"
127.0.0.1:6379> HGETALL items:1001
1) "id"
2) "3"
3) "name"
4) "apple"
5) "price"
6) "999.9"

java代码参考测试工程。

03-list列表

添加节点
删除节点
127.0.0.1:6379> lpush lkey1 123
(integer) 1
127.0.0.1:6379> lpush lkey1 1 2 3
(integer) 4

向列表右边增加元素

127.0.0.1:6379> rpush lkey1 4 5 6
(integer) 7
127.0.0.1:6379> lrange lkey1 0 -1
1) "3"
2) "2"
3) "1"
4) "123"
5) "4"
6) "5"
7) "6"
127.0.0.1:6379> lrange lkey1 0 3
1) "3"
2) "2"
3) "1"
4) "123"
127.0.0.1:6379> lrange lkey1 0 -1
1) "3"
2) "2"
3) "1"
4) "123"
127.0.0.1:6379> lpop lkey1
"3"
127.0.0.1:6379> rpop lkey1
"6"
127.0.0.1:6379> lrange lkey1 0 -1
1) "2"
2) "1"
3) "123"
4) "4"
5) "5"
127.0.0.1:6379> llen lkey1
(integer) 5

其他命令(自学)

127.0.0.1:6379> lrange lkey1 0 -1
1) "2"
2) "1"
3) "123"
4) "4"
5) "5"
127.0.0.1:6379> lrem lkey1 0 123
(integer) 1
127.0.0.1:6379> lrange lkey1 0 -1
1) "2"
2) "1"
3) "4"
4) "5"
127.0.0.1:6379> lrem lkey1 1 2
(integer) 1
127.0.0.1:6379> lrange lkey1 0 -1
1) "1"
2) "4"
3) "5"
127.0.0.1:6379> lrange lkey1 0 -1
1) "1"
2) "4"
3) "5"
127.0.0.1:6379> lindex lkey1 2
"5"
127.0.0.1:6379> lset lkey1 2 5
OK
127.0.0.1:6379> lrange lkey1 0 -1
1) "1"
2) "4"
3) "5"
127.0.0.1:6379> ltrim lkey1 0 1
OK
127.0.0.1:6379> lrange lkey1 0 -1
1) "1"
2) "4"
127.0.0.1:6379> lrange lkey1 0 -1
1) "1"
2) "4"
127.0.0.1:6379> linsert lkey1 after 4 3
(integer) 3
127.0.0.1:6379> lrange lkey1 0 -1
1) "1"
2) "4"
3) "3"
127.0.0.1:6379> lrange lkey1 0 -1
1) "1"
2) "4"
3) "3"
127.0.0.1:6379> rpoplpush lkey1 lkey2
"3"
127.0.0.1:6379> lrange lkey1 0 -1
1) "1"
2) "4"
127.0.0.1:6379> lrange lkey2 0 -1
1) "3"

应用

192.168.101.3:7001> LPUSH items:comment:1001 '{"id":1,"name":"商品不错,很好!!","date":1430295077289}'

java代码参考测试工程。

04-set集合

127.0.0.1:6379> sadd skey1 1 2 3 4 5
(integer) 5
127.0.0.1:6379> smembers skey1
1) "1"
2) "2"
3) "3"
4) "4"
5) "5"
127.0.0.1:6379> srem skey1 1
(integer) 1
127.0.0.1:6379> smembers skey1
1) "2"
2) "3"
3) "4"
4) "5"
127.0.0.1:6379> sismember skey1 1
(integer) 0
127.0.0.1:6379> sismember skey1 2
(integer) 1

测试元素的唯一性

127.0.0.1:6379> smembers skey1
1) "2"
2) "3"
3) "4"
4) "5"
127.0.0.1:6379> sadd skey1 2 3
(integer) 0
127.0.0.1:6379> sadd skey1 6 7
(integer) 2
127.0.0.1:6379> smembers skey1
1) "2"
2) "3"
3) "4"
4) "5"
5) "6"
6) "7"

其他命令

127.0.0.1:6379> sadd skey2 2 3 4 5 8 9 10
(integer) 7
127.0.0.1:6379> smembers skey1
1) "2"
2) "3"
3) "4"
4) "5"
5) "6"
6) "7"
127.0.0.1:6379> smembers skey2
1) "2"
2) "3"
3) "4"
4) "5"
5) "8"
6) "9"
7) "10"
127.0.0.1:6379> sdiff skey1 skey2
1) "6"
2) "7"
127.0.0.1:6379> sinter skey1 skey2
1) "2"
2) "3"
3) "4"
4) "5"
127.0.0.1:6379> sunion skey1 skey2
1) "2"
2) "3"
3) "4"
4) "5"
5) "6"
6) "7"
7) "8"
8) "9"
9) "10"

其它命令(自学)

127.0.0.1:6379> scard skey1
(integer) 6
127.0.0.1:6379> scard skey2
(integer) 7
127.0.0.1:6379> spop skey2
"10"
127.0.0.1:6379> smembers skey2
1) "2"
2) "3"
3) "4"
4) "5"
5) "8"
6) "9"
127.0.0.1:6379> spop skey2
"9"
127.0.0.1:6379> smembers skey2
1) "2"
2) "3"
3) "4"
4) "5"
5) "8"

05-sorted set有序集合(zset)

127.0.0.1:6379> zadd zkey1 80 zhangsan 70 lisi 92 wangwu
(integer) 3
127.0.0.1:6379> zscore zkey1 lisi
"70"
127.0.0.1:6379> zrange zkey1 0 -1
1) "lisi"
2) "zhangsan"
3) "wangwu"
127.0.0.1:6379> zrange zkey1 0 -1 withscores
1) "lisi"
2) "70"
3) "zhangsan"
4) "80"
5) "wangwu"
6) "92"
127.0.0.1:6379> zrevrange zkey1 0 -1 withscores
1) "wangwu"
2) "92"
3) "zhangsan"
4) "80"
5) "lisi"
6) "70"
127.0.0.1:6379> zrem zkey1 wangwu
(integer) 1
127.0.0.1:6379> zrange zkey1 0 -1 withscores
1) "lisi"
2) "70"
3) "zhangsan"
4) "80"

其他命令

127.0.0.1:6379> zadd zkey1 86 wangwu
(integer) 1
127.0.0.1:6379> zrangebyscore zkey1 80 87 withscores
1) "zhangsan"
2) "80"
3) "wangwu"
4) "86"
127.0.0.1:6379> zrangebyscore zkey1 80 85 withscores
1) "zhangsan"
2) "80"
127.0.0.1:6379> zincrby zkey1 4 lisi
"74"
127.0.0.1:6379> zrange zkey1 0 -1 withscores
1) "lisi"
2) "74"
3) "zhangsan"
4) "80"
5) "wangwu"
6) "86"
127.0.0.1:6379> zcard zkey1
(integer) 3
127.0.0.1:6379> zcount zkey1 80 86
(integer) 2
127.0.0.1:6379> zremrangebyrank zkey1 0 1
(integer) 2
127.0.0.1:6379> zremrangebyscore zkey1 80 90
(integer) 1
127.0.0.1:6379> zrange zkey1 0 -1 withscores
(empty list or set)
127.0.0.1:6379> zrank zkey1 lisi
(integer) 0

从大到小

127.0.0.1:6379> zrevrank zkey1 lisi
(integer) 2

应用

06-keys命令

192.168.101.3:7002> set test 1      设置test的值为1
OK
192.168.101.3:7002> get test            获取test的值
"1"
192.168.101.3:7002> EXPIRE test 5    设置test的生存时间为5秒
(integer) 1
192.168.101.3:7002> TTL test            查看test的生于生成时间还有1秒删除
(integer) 1
192.168.101.3:7002> TTL test
(integer) -2
192.168.101.3:7002> get test            获取test的值,已经删除
(nil)
redis 127.0.0.1:6379> keys mylist*
1) "mylist"
2) "mylist5"
3) "mylist6"
4) "mylist7"
5) "mylist8"
redis 127.0.0.1:6379> exists HongWan
(integer) 0
redis 127.0.0.1:6379> exists age
(integer) 1
redis 127.0.0.1:6379>

从结果来数据库中不存在HongWan 这个key,但是age 这个key 是存在的

redis 127.0.0.1:6379> del age
(integer) 1
redis 127.0.0.1:6379> exists age
(integer) 0
redis 127.0.0.1:6379>

从结果来数据库中不存在HongWan 这个key,但是age 这个key 是存在的

redis 127.0.0.1:6379[1]> keys *
1) "age"
redis 127.0.0.1:6379[1]> rename age age_new
OK
redis 127.0.0.1:6379[1]> keys *
1) "age_new"
redis 127.0.0.1:6379[1]>

age 成功的被我们改名为age_new 了

redis 127.0.0.1:6379> type addr
string
redis 127.0.0.1:6379> type myzset2
zset
redis 127.0.0.1:6379> type mylist
list
redis 127.0.0.1:6379>

这个方法可以非常简单的判断出值的类型

07-服务器命令

redis 127.0.0.1:6379> ping
PONG

//执行下面命令之前,我们停止redis 服务器

redis 127.0.0.1:6379> ping
Could not connect to Redis at 127.0.0.1:6379: Connection refused

//执行下面命令之前,我们启动redis 服务器

not connected> ping
PONG
redis 127.0.0.1:6379>

第一个ping 时,说明此连接正常
第二个ping 之前,我们将redis 服务器停止,那么ping 是失败的
第三个ping 之前,我们将redis 服务器启动,那么ping 是成功的

redis 127.0.0.1:6379> echo HongWan
"HongWan"
redis 127.0.0.1:6379>
redis 127.0.0.1:6379> select 1
OK
redis 127.0.0.1:6379[1]> select 16
(error) ERR invalid DB index
redis 127.0.0.1:6379[16]>

当选择16 时,报错,说明没有编号为16 的这个数据库

redis 127.0.0.1:6379> quit
redis 127.0.0.1:6379> dbsize
(integer) 18
redis 127.0.0.1:6379>

结果说明此库中有18 个key

redis 127.0.0.1:6379> info
redis_version:2.2.12
redis_git_sha1:00000000
redis_git_dirty:0
arch_bits:32
multiplexing_api:epoll
process_id:28480
uptime_in_seconds:2515
uptime_in_days:0
、、、、、
、、、、、
redis 127.0.0.1:6379> dbsize
(integer) 18
redis 127.0.0.1:6379> flushdb
OK
redis 127.0.0.1:6379> dbsize
(integer) 0
redis 127.0.0.1:6379>

在本例中我们将0 号数据库中的key 都清除了。

redis 127.0.0.1:6379[1]> dbsize
(integer) 1
redis 127.0.0.1:6379[1]> select 0
OK
redis 127.0.0.1:6379> flushall
OK
redis 127.0.0.1:6379> select 1
OK
redis 127.0.0.1:6379[1]> dbsize
(integer) 0
redis 127.0.0.1:6379[1]>

在本例中我们先查看了一个1 号数据库中有一个key,然后我切换到0 号库执行flushall 命令,结果1 号库中的key 也被清除了,说是此命令工作正常。

08-持久化(了解)

注意:因为在开发中,redis都用来做缓存数据库,完整性数据保存在关系型数据库(如mysql)中,当数据丢失时,可以从关系型数据库中再读取一次,所以在开发中一般选择rdb方案

09-主从复制(了解)

完整复制的问题:
  在redis2.8之前从redis每次同步都会从主redis中复制全部的数据,如果从redis是新创建的从主redis中复制全部的数据这是没有问题的,但是,如果当从redis停止运行,再启动时可能只有少部分数据和主redis不同步,此时启动redis仍然会从主redis复制全部数据,这样的性能肯定没有只复制那一小部分不同步的数据高。

上一篇下一篇

猜你喜欢

热点阅读