您当前的位置:首页 > 电脑百科 > 数据库 > Redis

Redis学习之数据操作

时间:2019-12-04 10:30:39  来源:  作者:

key 操作

  • 删除 key:del key
  • 批量删除key:redis-cli -a(密码)keys “QXJ_*”| xargs redis-cli -a(密码)del
  • 查看所有的 key(一次性遍历整个数据库,生产上慎重使用):keys [pattern]
  • 利用 cursor 分页查询记录(渐进的遍历整个数据库,生产上推荐):scan cursor [MATCH pattern] [COUNT count]
scan 0 match '*order*' count 20
  • 序列化给定 key,并返回被序列化的值:dump key
  • 检查给定 key 是否存在:exists key
  • 为 key 设置过期时间(秒)/ (时间戳)/(毫秒):expire key seconds / expireat key timestamp / pexpire key milliseconds
  • 移除 key 的过期时间,key 将持久保存:persist key
  • 以毫秒为单位返回 key 的剩余过期时间:pttl key
  • 返回 key 所存储的值得类型:type key
  • 返回从当前数据库中随机选择的一个key:randomkey
  • 原子的重命名一个key :rename oldkey newkey

Redis 的超时处理机制?

  • 当 client 主动访问 key 会先对 key 进行超时判断,过时的 key 会立刻删除。
  • master 的后台,会每秒做 10 次如下操作 — 随机选取 100 个key校验是否过期,如果有25个以上的 key 过期了,立刻额外随机选取下 100 个key(不计算在10次之内)。

Redis 的中文显示问题?

在 redis-cli 中使用中文时,必须打开 --raw 选项,才能正常显示中文。

/usr/bin/redis-cli --raw

string 操作

  • 保存 key 和 value(nx 表示 key 不存在的时候才赋值,xx 相反):set key value [ex 秒数] / [px 毫秒数] [nx] /[xx]
  • 仅当 key 不存在的时候才赋值(常用来做分布式锁):setnx key value
  • 原子的设置 key 的值,并返回 key 的旧值(配合 setnx 实现分布式锁):getset key value
  • 批量设置 key、value 的值:mset key1 value1 … keyN valueN
  • 获取/批量获取 value 值:get key / mget key1….keyN
  • 对 key 的值做加1或减1操作:incr/decr key
  • 对 key 的值指定加/减某个数值:incrby/decrby key integer、incrbyfloat key floatnumber
  • 对 key 的 value 追加值:Append key value
  • 返回截取过的 key 的字符串值,注意并不修改 key 的值:substr key start end
  • 位操作(位置相反,右边表示低位,offset 过大,则会在中间填充0):setbit key offset value、getbit key offset

list 操作

  • 向列表左边插入元素:lpush key value [value …]
  • 从列表右边移出元素:rpop key
  • 在 key 对应 list 的特定位置之前或之后添加字符串元素:linsert key before|after pivot value
linsert mylist before "world" "there"
  • 返回 key 对应 list 的长度:llen key
  • 通过索引获取列表中的元素:lindex key index
  • 获取列表指定范围内的元素(-1 表示最后一个元素):lrange key start end
  • 保留指定区间内元素:ltrim key start end
  • 设置list中指定下标的元素值:lset key index value
  • 从列表右边移出元素的阻塞方式,采取先到先服务原则,timeout 未获取到则返回 nil:brpop key [key …] timeout

set 操作

  • 添加元素:sadd key value
  • 移除元素,成功返回1:srem key
  • 移除集合中的一个随机元素并返回:spop key
  • 返回集合中一个或多个随机数:srandmember key count
  • 根据 key 获得集合中的所有成员:smembers key
  • 判断 member 是否在 set 中:sismember key member
  • 获取集合的成员数:scard key
  • 把 member 从 source 集合转移到 des 集合:smove source des member
  • 返回给定集合的差集:sdiff key1 key2
  • 返回给定集合的并集:sunion key1 key2
  • 返回给定集合的交集:sinter key1 key2…keyN

zset 操作

  • 添加元素到集合:zadd key score member
  • 删除元素:zrem key member
  • 返回集合中的元素数量:zcard key
  • 返回指定元素对应的 score:zscore key element
  • 增加对应 member 的 score 值,保持有序,返回更新后的 score 值:zincrby key incr member
  • 返回指定元素在集合中的排名,顺序/逆序:zrank/zrevrank key member
  • 返回有序集合中,指定范围内的元素:zrange key start end (zrange key 0 -1)
  • 返回有序集合中,指定分数区间内的元素(可以指定 inf 为无穷,withscores 表示需要返回分数):zrangebyscore key min max (zrangebyscore key -inf inf withscores)
  • 评分的聚合:zunionstore destination numkeys key [key …] [weights weight] [aggregate sum | min | max]
zunionstore award 2 visits votes weights 1 2 aggregate sum
  • destination:表示生成的目标集合
  • numkeys:需要聚合的集合数量,对应后面的 key [key …] 数量和
  • weights:乘法因子,默认为 1,每个给定有序集的所有成员的 score 值在传递给聚合函数(aggregation function)之前都要先乘以该因子
  • aggregate:集合函数,有 sum、min、max

hash 操作

  • 存储/批量存储 hash 值:hset key field value / hmset key field1 value1 field2 value2
  • 获取/批量获取 hash 值:hget key field / hmget key filed1….fieldN
  • 得到 hash 中的所有值:hgetall key
  • 测试指定 field 是否存在:hexists key field
  • 删除一个或多个哈希字段:hdel key field1 [field2]
  • 返回 hash 的所有 field:hkeys key
  • 返回指定 hash 的 field 数量:hlen key

HyperLogLog 操作

HyperLogLog 主要解决大数据应用中的非精确计数(可能多也可能少,但是会在一个合理的范围) 操作,它可以接受多个元素作为输入,并给出输入元素的基数估算值,基数指的是集合中不同元素的数量。

HyperLogLog 的优点是,即使输入元素的数量或者体积非常非常大,计算基数所需的空间总是固定的、并且是很小的。在 Redis 里面,每个 HyperLogLog 键只需要花费 12 KB 内存,就可以计算接近 2^64 个不同元素的基数。关于数据误差,在一个大小为 12k 的 key 所存储的 hyperloglog 集合基数计算的误差约是 0.81%。

因为 HyperLogLog 只会根据输入元素来计算基数,而不会储存输入元素本身,所以 HyperLogLog 不能像集合那样,返回输入的各个元素。

HyperLogLog 的这个数据结构可以非常省内存的去统计各种计数,比如注册 IP 数、每日访问 IP 数、页面实时UV 、在线用户数等。

  • 将元素添加至 HyperLogLog :pfadd key element [element …]
  • 返回给定 HyperLogLog 的基数估算值(多个 HyperLogLog 会先对 HyperLogLog 作并集处理):pfcount key [key …]
  • 合并多个 HyperLogLog:pfmerge destkey sourcekey [sourcekey …]


Tags:Redis   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
来源: my.oschina.net/xiaomu0082/blog/2990388首先说下问题现象:内网sandbox环境API持续1周出现应用卡死,所有api无响应现象刚开始当测试抱怨环境响应慢的时候 ,我们重启一下应...【详细内容】
2021-12-08  Tags: Redis  点击:(18)  评论:(0)  加入收藏
我不知道为什么你会选择对特定数量的“错误”(或警告)如此具体。听起来您正在寻找将要发布到 Yahoo! 的某些文章的内容。 Insider (N Foos to Blah for the BlahBlah)。那说:...【详细内容】
2021-12-07  Tags: Redis  点击:(14)  评论:(0)  加入收藏
目录 一、背景 二、步骤 0.理论支持 1、获取数据 2、结果 3、分析数据并评估大小 三、关于repl-backlog-size 一、背景 repl-backlog-size控制这个环形缓冲区. ​ 主从断...【详细内容】
2021-11-05  Tags: Redis  点击:(41)  评论:(0)  加入收藏
Redis 性能测试是通过同时执行多个命令实现的。1,Redis-benchmarkRedis性能命令:redis性能命令格式: redis-benchmark [option] [option value] redis 性能测试工具可选参数如...【详细内容】
2021-11-02  Tags: Redis  点击:(41)  评论:(0)  加入收藏
1 概述数据结构和内部编码 无传统关系型数据库的 Table 模型schema 所对应的db仅以编号区分。同一 db 内,key 作为顶层模型,它的值是扁平化的。即 db 就是key的命名空间。 key...【详细内容】
2021-11-01  Tags: Redis  点击:(28)  评论:(0)  加入收藏
普通java中使用引用Java redis 驱动,即可连接:import redis.clients.jedis.Jedis; public class RedisTestJava { public static void main(String[] args) { //连...【详细内容】
2021-10-13  Tags: Redis  点击:(34)  评论:(0)  加入收藏
Redis常用的数据结构有 string list set zset hashstringstring 是 Redis 的基本的数据类型,一个 key 对应一个 value。string 类型是二进制安全的,Redis的string可以包含任...【详细内容】
2021-10-12  Tags: Redis  点击:(36)  评论:(0)  加入收藏
列表类型可以存储一组按插入顺序排序的字符串,它非常灵活,支持在两端插入、弹出数据,可以充当栈和队列的角色。> LPUSH fruit apple(integer) 1> RPUSH fruit banana(integer)...【详细内容】
2021-09-17  Tags: Redis  点击:(54)  评论:(0)  加入收藏
Redis持久化意义 是做灾难恢复,数据恢复,也可以归类到高可用的一个环节里面去,比如你的redis整个挂了,然后redis就不可用了,你要做的事情是让redis变得可用,尽快变得可用 大量的请...【详细内容】
2021-08-12  Tags: Redis  点击:(77)  评论:(0)  加入收藏
Nginx来限制访问控制的方法有多种,nginx主要有2个模块控制,但是那些不支持自定义,非常死,在大多数场景下并不实用。今天分享一个:利用openresty+lua+redis 实现封杀频繁恶意访问I...【详细内容】
2021-08-12  Tags: Redis  点击:(119)  评论:(0)  加入收藏
▌简易百科推荐
来源: my.oschina.net/xiaomu0082/blog/2990388首先说下问题现象:内网sandbox环境API持续1周出现应用卡死,所有api无响应现象刚开始当测试抱怨环境响应慢的时候 ,我们重启一下应...【详细内容】
2021-12-08  Java识堂    Tags:Redis   点击:(18)  评论:(0)  加入收藏
我不知道为什么你会选择对特定数量的“错误”(或警告)如此具体。听起来您正在寻找将要发布到 Yahoo! 的某些文章的内容。 Insider (N Foos to Blah for the BlahBlah)。那说:...【详细内容】
2021-12-07  富集云科技有限公司    Tags:Redis   点击:(14)  评论:(0)  加入收藏
目录 一、背景 二、步骤 0.理论支持 1、获取数据 2、结果 3、分析数据并评估大小 三、关于repl-backlog-size 一、背景 repl-backlog-size控制这个环形缓冲区. ​ 主从断...【详细内容】
2021-11-05  弈秋的美好生活    Tags:redis   点击:(41)  评论:(0)  加入收藏
Redis 性能测试是通过同时执行多个命令实现的。1,Redis-benchmarkRedis性能命令:redis性能命令格式: redis-benchmark [option] [option value] redis 性能测试工具可选参数如...【详细内容】
2021-11-02  川石信息    Tags:Redis   点击:(41)  评论:(0)  加入收藏
1 概述数据结构和内部编码 无传统关系型数据库的 Table 模型schema 所对应的db仅以编号区分。同一 db 内,key 作为顶层模型,它的值是扁平化的。即 db 就是key的命名空间。 key...【详细内容】
2021-11-01  JavaEdge    Tags:Redis   点击:(28)  评论:(0)  加入收藏
普通java中使用引用Java redis 驱动,即可连接:import redis.clients.jedis.Jedis; public class RedisTestJava { public static void main(String[] args) { //连...【详细内容】
2021-10-13  faesuite    Tags:Redis   点击:(34)  评论:(0)  加入收藏
Redis常用的数据结构有 string list set zset hashstringstring 是 Redis 的基本的数据类型,一个 key 对应一个 value。string 类型是二进制安全的,Redis的string可以包含任...【详细内容】
2021-10-12  语霖    Tags:Redis   点击:(36)  评论:(0)  加入收藏
列表类型可以存储一组按插入顺序排序的字符串,它非常灵活,支持在两端插入、弹出数据,可以充当栈和队列的角色。> LPUSH fruit apple(integer) 1> RPUSH fruit banana(integer)...【详细内容】
2021-09-17  深夜敲代码    Tags:Redis   点击:(54)  评论:(0)  加入收藏
Redis持久化意义 是做灾难恢复,数据恢复,也可以归类到高可用的一个环节里面去,比如你的redis整个挂了,然后redis就不可用了,你要做的事情是让redis变得可用,尽快变得可用 大量的请...【详细内容】
2021-08-12  小李说IT    Tags:Redis   点击:(77)  评论:(0)  加入收藏
当查询Redis中没有的数据时,该查询会下沉到数据库层,同时数据库层也没有该数据,当这种情况大量出现或被恶意攻击时,接口的访问全部透过Redis访问数据库,而数据库中也没有这些数据...【详细内容】
2021-07-30  随便t    Tags:缓存穿透   点击:(91)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条