Redis学习二(数据操作).
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学习二(数据操作).的更多相关文章
- Redis学习笔记-数据操作篇(Centos7)
一.基本操作 1.插入数据 127.0.0.1:6379> set name cos1eqlg0 OK 这样就在redis中设置了一个key-value键值对 2.查询数据 127.0.0.1: ...
- [Python] Python 学习 - 可视化数据操作(一)
Python 学习 - 可视化数据操作(一) GitHub:https://github.com/liqingwen2015/my_data_view 目录 折线图 散点图 随机漫步 骰子点数概率 文 ...
- Redis简单的数据操作(增删改查)
#Redis简单的数据操作(增删改查): 字符串类型 string 1. 存储: set key value 127.0.0.1:6379> set username zhangsan OK 2 ...
- Redis学习二 C#中如何进行这五种数据类型的操作
我在网上找了好久,就是没有找到Redis和C#结合的书,都是和别的编程语言在一起鬼混. 简单的用C#实现向Redis中插入那我中类型的数据 首先需要到NuGet 里面下载 Redis IDatabas ...
- Redis学习二:Redis高并发之主从模式
申明 本文章首发自本人公众号:壹枝花算不算浪漫,如若转载请标明来源! 感兴趣的小伙伴可关注个人公众号:壹枝花算不算浪漫 22.jpg 前言 前面已经学习了Redis的持久化方式,接下来开始学习Redi ...
- redis学习(二)——案例练习
案例需求: 1.提供index.html页面,页面中有一个省份下拉列表 2.当页面加载完成后发送ajax请求,加载所有省份 3.列表中的省份保持不变,则之后每次刷新页面都是从redis中获取 * 注意 ...
- linux学习之——数据操作:添加与查询
说明: 在linux系统中,利用搭建的服务器,编写两个页面,一个添加信息,一个展现信息: 主要涉及到:php+mysql的操作: 数据添加页面: <html> <head> & ...
- Redis 学习(二) —— 数据类型及操作
Redis支持string.list.set.zset.hash等数据类型,这一篇学习redis的数据类型.命令及某些使用场景. 一.String,字符串 字符串是 Redis 最基本的数据类型.一个 ...
- C#中使用Redis学习二 在.NET4.5中使用redis hash操作
上一篇>> 摘要 上一篇讲述了安装redis客户端和服务器端,也大体地介绍了一下redis.本篇着重讲解.NET4.0 和 .NET4.5中如何使用redis和C# redis操作哈希表. ...
随机推荐
- warning: rpmts_HdrFromFdno: Header V4 DSA/SHA1 Signature, key ID XXXXXX: NOKEY
我在使用Centos时,会出现这种错误: 本人实践有效的办法是: 加上"--nogpgcheck"参数 就是在你要执行的语句后面加上该参数就行了! 我当时是为了安装jenkins时 ...
- java关键字 保留字
Java 关键字和保留字 Java 关键字列表 (依字母排序 共51组): abstract, assert,boolean, break, byte, case, catch, char, clas ...
- Spring IOC容器装配Bean_基于XML配置方式
开发所需jar包 实例化Bean的四种方式 1.无参数构造器 (最常用) <?xml version="1.0" encoding="UTF-8"?> ...
- 《Windows内核安全与驱动开发》 5.1&5.2 内核与应用方面的编程
<Windows内核安全与驱动开发>阅读笔记 -- 索引目录 <Windows内核安全与驱动开发> 5.1&5.2 内核与应用方面的编程 一.生成控制设备 如果一个驱 ...
- Netty实现丢弃服务协议(Netty4.X学习一)
何为丢弃服务(Discard Protocol),丢弃服务就是一个协议,是最简单的协议,它的作用是接受到什么就丢弃什么,它对调试网路状态有一定的用处.基于TCP的丢弃服务,服务器实现了丢弃丢弃协议,服 ...
- nginx的部署及配置文件的介绍 域名 用户认证 SSL加密模块
步骤一:构建Nginx服务器 yum -y install gcc pcre-devel openssl-devel #安装依赖包 wget http://nginx.org/dow ...
- luogu P1566 加等式
题目描述 对于一个整数集合,我们定义"加等式"如下:集合中的某一个元素可以表示成集合内其他元素之和.如集合{1,2,3}中就有一个加等式:3=1+2,而且3=1+2 和3=2+1是 ...
- python数据挖掘第一篇:正则表达式
正则表达式 re 模块 re.match(pattern,string[,flag]) match方法 从首字母开始匹配,如果包含pattern字符串,则匹配成功,返回match对象,失败则返回Non ...
- border-radius:50%和100%的区别
border-radius 值类型-百分比 border-radius的值是百分比的话,就相当于盒子的宽度和高度的百分比. 我们知道在一个正方形内做一个面积最大的圆形,这个圆的半径就为正方形边长的一半 ...
- go实践之apiserver搭建
文章目录 go实践之apiserver搭建 1.配置文件读取 2.数据连接 3.日志初始化 4.server初始化 5.接口编写 go实践之apiserver搭建 本文主要记录下博主用gin搭建app ...