<Redis> 入门二 五种数据类型的操作、通用key的操作、发布订阅
文档参考:http://www.redis.net.cn/
string - > key value 简单的keyvalue,常规计数:例如微博数,粉丝数
set -> key value1 value2... 去重,所以保存用户的所有关注,粉丝。通过交集并集差集,可以实现共同关注,共同爱好等
sortedset -> key score1 value1 score2 value2 排行榜,代权重的消息队列
hash -> map [key1,value1 key2,value2...] 存对象,例如用户信息
list -> 队列key value1 ..value2...value3.. 做分布式消息队列,最新消息排行
1.String 类型
重复会覆盖之前的key值
一个字符类型的key默认存储最大容量是512M
set key value 设置指定的key,value值
get key 获取指定的key值
getrange key start end 返回key中包含头尾的子字符串
getset key value 设置指定的key,value 返回旧的value,如果没有旧value,返回(nil),并设置key value
setex key second value 设置key,value,并指定过期时间,单位为秒
psetex key milliseconds value 设置key,value,并指定过期时间,单位为毫秒
setnx key value 只有当不存在key时,才能设置成功
strlen key 返回字符串的长度
incr key 给key存储的数值加1,有原子性
incrby key increment 给key存储的数值指定加increment
incrbyfloat key increment 给key存储的数值指定加浮点类型
decr num 给key存储的数值减一
decrby num decrement 给key存储的数值减decrement
append key value 给key后追加字符
del key 删除key
mget key1[key2] 获取多个键的值,可以减少网络传输
mset key value[key value] 可以设置多个键值
2.hash类型
字段名重复会覆盖之前的field的值
Redis hash 是一个string类型的field和value的映射表,hash特别适合用于存储对象。
Redis 中每个 hash 可以存储 232 - 1 键值对(40多亿)
适合存储对象
person:
name:zhangsan
age:18
sex:男
hset key field value 设置哈希key中的field的值为value,可以设置多个
hget key field 获取哈希key中的field对应的value值
hgetall key 获取哈希key中所有的键值对
hexists key field 判断哈希key中对应的字段是否存在
hdel key field 删除key中指定的字段
hincrby key field increment 给指定的哈希的字段数字增加increment
hincrbyfloat key field increment 给指定的哈希的字段数字增加浮点increment
hkeys key 获取哈希key中的所有字段
hlen key 获取哈希key中字段的个数
hvals key 获取hash表中所有字段对应的值
hsetnx key field value 只有当field字段不存在,设置哈希表字段的值
3.list类型
Redis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)
一个列表最多可以包含 232 - 1 个元素 (4294967295, 每个列表超过40亿个元素)。
允许重复元素
可以实现分部式消息队列
lpush key value 将值插入列表头部,key是列表名,value是指
rpush key value 将值插入列表尾部
lrange key start stop 查询列表中的值,0 -1 表示所有
lpushx key value 向已存在的列表头部添加值
rpushx key value 向已存在的列表尾部添加至
lpop key 弹出左边第一个元素,并返回元素值
rpop key 弹出右边第一个元素,并返回元素值
llen key 获取列表长度
blpop key timeout 移除第一个元素,直到等待超时,或发现弹出为止
brpop key timeout 移除最后一个元素,直到等待超时,或发现弹出为止
4.set类型
Redis的Set是string类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。
Redis 中 集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。
集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。
sadd key value[value...] 向key集合中添加多个元素,如果存在,则会忽略存在的值,并返回成功加入的元素个数
scard key 获取key集合中元素个数
sdiff key1 [key2] 返回两个集合的差集
sdiffstore destination key1[key2] 将两个集合的差集存储到目标集合destination中
smembers key 返回集合中的所有成员
sinter key1 [key2] 返回两个集合的交集
sinter destination key1 [key2] 返回两个集合的交集并存储到目标集合
sunion key1[key2] 将所有集合的并集显示出来
sunionstore destination key1[key2] 将所有集合的并集返回到destination中
sismember key value 判断value是不是key中的元素
spop key count 随机移除集合中的元素,count代表个数,返回移除的元素
.
srandmember key count 返回集合中count个随机值
srem key value[value] 移除集合中一个元素或多个元素
5.sortedSet类型
Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
有序集合的成员是唯一的,但分数(score)却可以重复。
集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)
zadd key score1 member1[score2 member2] 向key集合添加分数和成员
zcard key 查看key集合中有几个元素
zrange key start end withscores 显示集合中start 到 end 集合并且显示分数
zcount key min max 计算集合元素中指定区间分数的成员数
zscore key value 返回指定成员的分数值
zrem key value 移除key集合中的指定成员
6.key 通用命令
keys * 查看所有的键
type key 获取键对应的类型
del key 删除指定的key
rename key newkey 修改key的名字
exists key 检查key是否存在
expire key seconds 给key设置过期时间,单位是秒
ttl key 查看还多少秒过期,-1为持久化
pttl key 查看还多久过期,单位毫秒
persist 去掉过期时间,持久化
move key bd 将当前的key移动到指定的数据库
发布订阅
publish channal message
subscribe channel [...]
<Redis> 入门二 五种数据类型的操作、通用key的操作、发布订阅的更多相关文章
- 【Redis】一、Redis简介及五种数据类型
(一)Redis简介 Redis(Remote Dictionary Server)是一个使用ANSI C语言编写.遵守BSD协议.支持网络.可基于内存亦可持久化的日志型.Key-Value的开源 ...
- Redis支持的五种数据类型
redis支持的五种数据类型: 1.string(字符串) 2.hash(哈希) Redis hash 是一个键值(key=>value)对集合. Redis hash是一个string类型的f ...
- Redis学习笔记(3)—— 五种数据类型&keys的通用操作
一.Redis数据结构介绍 redis是一种高级的key-value的存储系统,其中的key是字符串类型,尽可能满足如下几点: 1)key不要太长,最好不要操作1024个字节,这不仅会消耗内存还会降低 ...
- 《闲扯Redis一》五种数据类型之String型
一.前言 Redis 提供了5种数据类型:String(字符串).Hash(哈希).List(列表).Set(集合).Zset(有序集合),理解每种数据类型的特点对于redis的开发和运维非常重要. ...
- Redis安装及五种数据类型
redis是非关系型数据库,也叫内存数据库.数据是键值对的形式,通过key查找value 安装Radis:6379 sudo apt-get update sudo apt-get install r ...
- Redis学习笔记--五种数据类型的使用场景
String 1.String 常用命令: 除了get.set.incr.decr mget等操作外,Redis还提供了下面一些操作: 获取字符串长度 往字符串append内容 设置和获取字符串的某一 ...
- redis的入门篇---五种数据类型及基本操作
查看所有的key keys * 清空所有的key flushall 检查key是否存在 exists key 设置已存在的key的时长 expire key //设置key为10s 查看key还剩多少 ...
- 《闲扯Redis三》Redis五种数据类型之List型
一.前言 Redis 提供了5种数据类型:String(字符串).Hash(哈希).List(列表).Set(集合).Zset(有序集合),理解每种数据类型的特点对于redis的开发和运维非常重要. ...
- Redis五种数据类型应用场景
目录 1.1 回顾 2.1 应用场景 2.1.1 String 2.1.2 Hash 2.1.3 List 2.1.4 Zet 2.1.5 zset 3.1 小结 1.1 回顾 Redis的五种数据类 ...
随机推荐
- jvm学习理解
1.本文是转载别人所写的,因为这个jvm看很多遍老是忘,转载只是备忘和查看方便. 转载地址: https://mp.weixin.qq.com/s/reFDCkUdq1QGGDs_Mnuesg 图中涉 ...
- Windows 中属于不同Owner的Workspace 互相无法看见,且无法删除
Windows 中属于不同Owner的Workspace 互相无法看见,且无法删除 而且不能重叠,重叠的话会报错,告诉你这个文件夹已经被其他用户映射, 所以你必须以那个Owner登陆tfs,然后删除 ...
- bzoj 1025: [SCOI2009]游戏【数学+dp】
很容易发现行数就是lcm环长,也就是要求和为n的若干数lcm的个数 有结论若p1^a1+p2^a2+...+pm^am<=n,则ans=p1^a1p2^a2..*pm^am是n的一个可行答案.( ...
- 【爬坑系列】之vxlan网络实现
linux 内核从3.7之后就内部集成了vxlan功能,所以可以使用linux内核提供的vxlan功能,经过配置创建vxlan网络. 而从Docker自Docker Engine 1.9之后,就自带o ...
- JAVA大数处理(BigInteger,BigDecimal)
原文链接 Java中有两个类BigInteger和BigDecimal分别表示大整数类和大浮点数类. 这两个类都在java.math.*包中,因此每次必须在开头处引用该包. Ⅰ基本函数: 1.valu ...
- 构造 HDOJ 5414 CRB and String
题目传送门 题意:给两个字符串s,t,可以在s字符串任意位置后面插入字符c(与前面的不同),问是否能够将s转换为t字符串 构造:首先lens > lent 或者 s[1] != t[1] 一定是 ...
- HttpURLConnection与HTTP Client的区别,及多用前者
转自: http://android-developers.blogspot.jp/2011/09/androids-http-clients.html Level 9以前用client,以后用url ...
- selenium 延迟等待的三种方式
1.最直接普通的方式:这个是设置固定的等待时间 Thread.sleep(1000); 2.显示等待方式(Explicit Wait):就是明确的要等待的元素在规定的时间之内都没找到,那么就 ...
- Elixir安装
参考:https://laravel.com/docs/5.2/elixir 1. 安装node 去这里下载 2.可以用淘宝的cnpm加速! npm install -g cnpm --registr ...
- 移动端UI自动化Appium测试——Appium server两种启动方式
执行自动化测试之前,需要先运行appium server,这样才能形成server与java client的通信,启动server有两种方式,一种是命令,一种是按钮图标,具体使用如下: 1.用命令启动 ...