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 ...]

Redis学习二(数据操作).的更多相关文章

  1. Redis学习笔记-数据操作篇(Centos7)

    一.基本操作 1.插入数据 127.0.0.1:6379> set name cos1eqlg0 OK 这样就在redis中设置了一个key-value键值对 2.查询数据 127.0.0.1: ...

  2. [Python] Python 学习 - 可视化数据操作(一)

    Python 学习 - 可视化数据操作(一) GitHub:https://github.com/liqingwen2015/my_data_view 目录 折线图 散点图 随机漫步 骰子点数概率 文 ...

  3. Redis简单的数据操作(增删改查)

    #Redis简单的数据操作(增删改查): 字符串类型 string 1. 存储: set key value 127.0.0.1:6379> set username zhangsan OK 2 ...

  4. Redis学习二 C#中如何进行这五种数据类型的操作

    我在网上找了好久,就是没有找到Redis和C#结合的书,都是和别的编程语言在一起鬼混. 简单的用C#实现向Redis中插入那我中类型的数据 首先需要到NuGet 里面下载 Redis IDatabas ...

  5. Redis学习二:Redis高并发之主从模式

    申明 本文章首发自本人公众号:壹枝花算不算浪漫,如若转载请标明来源! 感兴趣的小伙伴可关注个人公众号:壹枝花算不算浪漫 22.jpg 前言 前面已经学习了Redis的持久化方式,接下来开始学习Redi ...

  6. redis学习(二)——案例练习

    案例需求: 1.提供index.html页面,页面中有一个省份下拉列表 2.当页面加载完成后发送ajax请求,加载所有省份 3.列表中的省份保持不变,则之后每次刷新页面都是从redis中获取 * 注意 ...

  7. linux学习之——数据操作:添加与查询

    说明: 在linux系统中,利用搭建的服务器,编写两个页面,一个添加信息,一个展现信息: 主要涉及到:php+mysql的操作: 数据添加页面: <html> <head> & ...

  8. Redis 学习(二) —— 数据类型及操作

    Redis支持string.list.set.zset.hash等数据类型,这一篇学习redis的数据类型.命令及某些使用场景. 一.String,字符串 字符串是 Redis 最基本的数据类型.一个 ...

  9. C#中使用Redis学习二 在.NET4.5中使用redis hash操作

    上一篇>> 摘要 上一篇讲述了安装redis客户端和服务器端,也大体地介绍了一下redis.本篇着重讲解.NET4.0 和 .NET4.5中如何使用redis和C# redis操作哈希表. ...

随机推荐

  1. 洛谷上的C语言三连击。

    注意看题目,没有0,一直错. #include<stdio.h> int panduan1(int num1,int num2, int num3); int main(){ int i, ...

  2. Spring Boot SpringApplication启动类(二)

    目录 前言 1.起源 2.SpringApplication 运行阶段 2.1 SpringApplicationRunListeners 结构 2.1.1 SpringApplicationRunL ...

  3. 基于webpack实现多html页面开发框架五 开发环境配置 babel配置

    一.解决什么问题      1.开发环境js.css不压缩,可在浏览器选中代码调试      2.开发环境运行http服务指向打包后的文件夹      3.babel输出浏览器兼容的js代码 二.需要 ...

  4. Dict.setdefault()

    """ setdefault方法参数输入已有键,返回对应值,找不到已有键,创建新键,值为None """ >>> dict ...

  5. STM32F4 阿波罗 库函数与C语言知识

    先聊一聊: 之前使用32都是用的库函数,但是没有理解为什么那么操作,有很多的文件我也不知道要看哪一个,感觉云里雾里,没有学清楚一件东西的感觉不太好,于是就在前几天一直跟着比较详细的视频学习.开始老师讲 ...

  6. 洛谷 题解 CF299A 【Ksusha and Array】

    本蒟蒻又双叒叕被爆踩辣! 这就是道大水题 首先,题目意思: 给你n个数,要你找这些数字中找到一个能够被这些所有数字整除的数,若有多个,可任意输出其中一个,其实答案只有一个,因为在大于等于自己的数中能被 ...

  7. 小白探究UE4网络系列(一)、UE4网络基础类分析

    转载请标明出处:http://www.cnblogs.com/zblade/ 一.概要 捣鼓UE4也有两个多月了,从这儿开始,逐步探究UE4中经典的值复制,RPC两种同步方式.想要弄到其复制和调用的原 ...

  8. luogu P1722 矩阵 II

    题目背景 usqwedf 改编系列题. 题目描述 如果你在百忙之中抽空看题,请自动跳到第六行. 众所周知,在中国古代算筹中,红为正,黑为负-- 给定一个1*(2n)的矩阵(usqwedf:这不是一个2 ...

  9. HTML <input> placeholder 属性

    css ::-webkit-input-placeholder { /* WebKit, Blink, Edge */ color: #909; } :-moz-placeholder { /* Mo ...

  10. kubernetes学习笔记(二)——部署服务

    文章目录 (1)创建app (2)创建app的docker镜像 (3)部署app到k8s (4)参考资料 前面一篇文章部署好了minikube环境,这次学习下怎么部署app到kubernetes环境当 ...