NoSql之深入浅出redis
一、常用命令1、String类型(1)set key value nx:如果key不存在则建立 xx:如果key存在则修改其值 (2)get key:取值 (3)mset key1 value1 key2 value2 一次设置多个值 (4)mget key1 key2 :一次获取多个值 (5)getrange key start stop:获取字符串中[start,stop]范围的值 对于字符串的下标,左数从0开始,右数从-1开始 注意:当start>length,则返回空字符串 当stop>=length,则截取至字符串尾 如果start所处位置在stop右边,则返回空字符串 (6)getset key nrevalue:获取并返回旧值,在设置新值 (7)incr key:自增,返回新值, 如果incr一个不是int的value则返回错误, incr一个不存在的key,则设置key为1 (8)incrby key 2:跳2自增 (9)strlen key:取指定key的value值的长度 (10)setex key time value:设置key对应的值value,并设置有效期为time秒
2、List类型(1)lpush key value:把值插入到链表头部
(2)rpush key value:把值插入到链表尾部
(3)lpop key :返回并删除链表头部元素
(4)rpop key: 返回并删除链表尾部元素
(5)lrange key start stop:返回链表中[start,stop]中的元素 (6)lrem key count value:从链表中删除value值,删除count的绝对值个value后结束 count > 0 从表头删除 count < 0 从表尾删除 count=0 全部删除 (7)ltrim key start stop:剪切key对应的链接,切[start,stop]一段并把改制重新赋给key (8)lindex key index:返回index索引上的值 (9)llen key:计算链表的元素个数 (10)linsert key after|before search value:在key 链表中寻找search,并在search值之前|之后插入value (11)rpoplpush source dest:把source 的末尾拿出,放到dest头部,并返回单元值
3、Hash类型 (1)hset myhash field value:设置myhash的field为value
(2)hsetnx myhash field value:不存在的情况下设置myhash的field为value
(3)hmset myhash field1 value1 field2 value2:同时设置多个field
(4)hget myhash field:获取指定的hash field
(5)hmget myhash field1 field2:一次获取多个field
(6)hincrby myhash field 5:指定的hash field加上给定的值
(7)hexists myhash field:测试指定的field是否存在
(8)hlen myhash:返回hash的field数量
(9)hdel myhash field:删除指定的field
(10)hkeys myhash:返回hash所有的field
(11)hvals myhash:返回hash所有的value
(12)hgetall myhash:获取某个hash中全部的field及value
4、Set类型 (1)sadd key value1 value2:往集合里面添加元素
(2)smembers key:获取集合所有的元素
(3)srem key value:删除集合某个元素
(4)spop key:返回并删除集合中1个随机元素(可以坐抽奖,不会重复抽到某人)
(5)srandmember key:随机取一个元素
(6)sismember key value:判断集合是否有某个值
(7)scard key:返回集合元素的个数
(8)smove source dest value:把source的value移动到dest集合中
(9)sinter key1 key2 key3:求key1 key2 key3的交集
(10)sunion key1 key2:求key1 key2 的并集
(11)sdiff key1 key2:求key1 key2的差集
(12)sinterstore res key1 key2:求key1 key2的交集并存在res里
5、Zset类型 (1)zadd key score1 value1:添加元素
(2)zrange key start stop [withscore]:把集合排序后,返回名次[start,stop]的元素 默认是升续排列 withscores 是把score也打印出来 (3)zrank key member:查询member的排名(升序0名开始) (4)zrangebyscore key min max [withscores]集合(升序)排序后取score在[min,max]内的元素 (5)zrevrank key member:查询member排名(降序 0名开始) (6)zremrangebyscore key min max:按照score来删除元素,删除score在[min,max]之间 (7)zrem key value1 value2:删除集合中的元素 (8)zremrangebyrank key start end:按排名删除元素,删除名次在[start,end]之间的 (9)zcard key:返回集合元素的个数 (10)zcount key min max:返回[min,max]区间内元素数量
二、高级特性1、事务
例子: redis 127.0.0.1:6379> multi
OK
redis 127.0.0.1:6379> incr a
QUEUED
redis 127.0.0.1:6379> incr b
QUEUED
redis 127.0.0.1:6379> exec
1. (integer) 1
2. (integer) 1
2、持久化
save 900 1 #900秒内如果超过1个key被修改,则发起快照保存
save 300 10 #300秒内容如超过10个key被修改,则发起快照保存
save 60 10000
appendonly yes #启用aof持久化方式
# appendfsync always #每次收到写命令就立即强制写入磁盘,最慢的,但是保证完全的持久化,不推荐使用
appendfsync everysec #每秒钟强制写入磁盘一次,在性能和持久化方面做了很好的折中,推荐
# appendfsync no #完全依赖os,性能最好,持久化没保证
3、主从复制
原理过程
4、发布订阅
下图展示了频道 channel1 , 以及订阅这个频道的三个客户端 —— client2 、 client5 和 client1 之间的关系: 当有新消息通过 PUBLISH 命令发送给频道 channel1 时, 这个消息就会被发送给订阅它的三个客户端: 总结:
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |