Redis内容总结

Redis支持五种的数据类型

1、String
2、hash
3、list
4、set
5、sorted set

String数据类型

getrange key start end:返回key中字符串值的子字符
setrange key offset value:用value参数覆写给定Key所存储的字符串值,从offset开始
strlen:获取字符串长度
set key value:设置key value
get key:获取value
setex key value: 原子方式设置key value
setbit key offset value:设置字符串offset位上的值,为0或1


hash数据类型

hlen :获取长度
hget key field :获取值
hset key field value:单个添加
hmset key field1 value1 field2 value2 ..一起添加
hexists key field判断键是否存在
hdel key field删除key中的一个field
hkeys key 获取所有哈希表中的字段
hvals key 获取哈希表中所有的值
hsetnx key field value :当key中field不存在,设置这个字段的值


list双端链表数据类型

llen :输出列表长度
lpush:左输入
rpush:右输入
blpop key timeout:移除并获取列表第一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。(假如在指定时间内没有任何元素被弹出,则返回一个 nil 和等待时长。 反之,返回一个含有两个元素的列表,第一个元素是被弹出元素所属的 key ,第二个元素是被弹出元素的值。)

brpop key timeout:移除并获取列表最后一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
lpop:简单移除并获取第一个元素
rpop:简单移除并获取最后一个元素
lindex key index:通过索引获取列表中的元素
lset key index value:通过索引设置列表元素的值
lrange key start stop:获取列表指定范围内的元素
ltrim key start stop:对列表进行修剪,只保留区间内的元素
rpoplpush source targe:将source链表最后一个元素弹出并且插入到targe链表中,最后返回这个元素的值


Set:String类型的无序集合,且不允许重复元素

sadd key value:添加元素
srem key member1 member2:移除集合中一个或多个成员

scard key :获取集合的成员数
smembers key :获取集合所有的成员
sismember key member:获取member是否是key中的

sdiff key1 key2:获取多个key的差集
sinter key1 key2:获取多个key的交集
sunion key1 key2:获取多个key的并集

smove sourve targe member:将sourve中的member移到targe中
spop key:移除并且返回集合中一个随机元素
srandmember key [count]:返回集合中一个或多个随机数


Sorted Set:有序集合

//与set类似,不同的是每个元素都会关联一个double类型的分数。
//redis正是通过分数来为集合中的成员进行从小到大的排序。

zadd key score1 member [score2 member2]:向有序集合添加一个或多个成员,或者更新已存在成员的分数
zrem key member [member..]移除有序集合中的一个或多个成员

/按照正常分数从低到高排序/
zrange key start stop :返回有序集合指定区间内的成员(默认从低到高排序)(start:0;end:-1代表查询这个Key所有的成员)
zrangebyscore key min max[withscores]:通过分数返回有序集合指定区间内的成员
zrank key member:返回该成员的索引

/rev代表的是reverse(反转)/
zrevrange key start stop[withscores]:返回有序集合指定区间内的成员,按照分数从高到低排序
zrevrangebyscore key max min[withscores]:返回有序集合指定分数区间内的成员,分数从高到低排序
zrevrank key member:返回有序集合中指定成员的排名,有序集合是按分数(从大到小)排序

zcard key :获取有序集合的成员数
zcount key min max:计算有序集合指定区间分数的成员数
zscore key member:返回该成员的分数值

zremrangebyrank key start stop:移除有序集合中给定排名区间的所有成员
zremrangebyscore key min max:移除给定分数区间的所有成员

zinterstore targe numkeys(交集的key个数) key1 key2..:计算给定一个或者多个有序集的交集并将结果存储到targe中
注意:此时交集结果成员的分数为多个有序集分数的总和
zunionstore targe numkeys key1 keys2:并集,与交集类似,最后的分数也是多个有序集分数的总和
注意:有序集合的redis没有提供多个集合差集的方法,这是跟无序集合的区别之一


redis发布订阅(redis用作消息队列)

1、subscribe channel[channel..] 订阅一个或者多个频道的信息
2、publish channel message 将消息发送到指定的频道
3、unsubscribe channel [channel ..] 退订一个或者多个频道的信息
4、psubscribe pattern [pattern ...] 订阅一个或者多个符合给定模式的频道
5、punsubscribe pattern [pattern ..] 退订一个或者多个符合给定模式的频道
6、pubsub subcommand [argument [argument]] 查看订阅与发布系统状态
参考链接:https://blog.csdn.net/qq_34212276/article/details/78455004

redis事务

redis事务可以一次执行多个命令,并且带有两个重要的保证:
1、redis使用multi开始一个事务,然后开始写redis命令,最后通过exec命令执行事务
exec命令执行事务的过程中有任意命令执行失败,其余命令依然被执行,之前执行的命令也不会回滚
2、事务执行过程中,其他客户端提交的命令请求不会插入到事务执行命令序列中

我们知道单个redis命令的执行是原子性的,但是redis事务不具备原子性机制,可以理解为一个打包批量执行的脚本

方法:
1、discard:取消事务,放弃执行事务块内所有命令
2、exec:执行所有事务块内的命令
3、multi:标记一个事务块的开始
4、unwatch:取消watch命令对所有Key的监视
5、watch key :监视一个或者多个key,如果在事务执行之前这个key被其他命令改动,那么事务将被打断

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,761评论 5 460
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,953评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,998评论 0 320
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,248评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,130评论 4 356
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,145评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,550评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,236评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,510评论 1 291
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,601评论 2 310
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,376评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,247评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,613评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,911评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,191评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,532评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,739评论 2 335

推荐阅读更多精彩内容