概念:Redis是用C语言开发的一个开源的高性能键值对数据库。redis
特征:shell
单个string类型的存储空间为512MB数据库
添加或修改数据数组
set key value
获取数据session
get key
删除数据架构
del key
设置过时时间(默认单位为秒)app
expire key second
追加信息到初始value后边分布式
append key value
添加/修改多个数据性能
mset key1 value1 key2 value2...
获取多个数据学习
mget key1 key2 ...
获取字符串长度
strlen key
设置key的生命周期 控制生命周期
setex key seconds value (秒) psetex key millisexxonds value (毫秒)
key的设置约定
与数据库中的表-主键-字段一一对应
表名 | 主键名 | 主键值 | 字段名 | |
---|---|---|---|---|
eg1 | order | id | 443523454 | name |
eg2 | equire | id | 435432543 | type |
eg3 | news | id | 45435454 | title |
- 存储需求: 对一系列存储的数据进行编排,方便管理,典型应用存储对象信息
- 存储结构:一个存储空间存储多个键值对数据
- hash类型:底层使用哈希表结构实现数据存储
hash存储结构优化
- 若是field数量较少,存储结构优化为类数组结构
- 若是field数量较多,存储结构使用HashMap结构
添加/修改数据
hset key field value
获取数据
hget key field hgetall key
删除数据
hdel key field [field2 ...]
添加或删除多个数据
hmset key field1 value1 field2 value2 ...
获取多个数据
hmget key field1 field2 ...
获取hash表中的字段的数量
hlen key
获取hash表中是否存在指定的字段
hexists key field
获取哈希表中所用的字段名或字段值
hkeys key hvalues key
设置指定字段的数值数据增长指定范围的值
hincrby key field increment hincrbyfloat key field increment
若是key值下的field存在则不作操做 不存在则添加进去
hsetnx key field value
hash类型下的value只能存储字符串,不容许存储其余数据类型,不存在嵌套现象,若是数据未获取到,对应的值为(nil)
每一个hash存储的键值对上限为
$$
2^{32}-1
$$
个键值对
hash类型十分贴近对象的存储形式,而且能够灵活删除对象属性。但hash设计初衷并非为了存储大量对象而设计的,切记不可滥用,更不可将hash做为对象列表使用
hgetall操做能够获取所有属性,若是内部field过多,遍历总体数据效率会很低,有可能会成为数据访问瓶颈
- 数据存储需求:存储多个数据,并对数据进入存储Jon关键的顺序进行区分
- 须要的存储结构:一个存储空间存储多个数据,而且数据能够体现进入顺序
- list类型:保存多个数据,底层使用双向链表存储结构实现
list类型是双向链表存储的
添加/修改数据
lpush key value1 value2 [value3] ... //从list链表左侧添加 rpush key value1 value2 [value3] ... //从list右侧添加
获取数据
lrange key start stop //指定链表起始结束位置中的value //在获取未知长的的list类型的时候,想查看全部的value可使用 -1表示倒数第一个 lrange key start -1 lindex key index //获取链表中指定位置的值 llen key //获取链表的长度
获取并移除数据
lpop key rpop key
规定时间内获取并移除数据(阻塞式数据获取)
blpop key1 [key2] timeout //指定时间内取出并移除key值对应的value,若timeout超时仍未取出则返回空值(nil) 若原本没有 其余客户端在等待的时候添加了这个key的value则作操做 任务队列 brpop key1 [key2] timeout
移除指定数据
lrem key count value
- 存储需求:存储大量的数据,在查询方面提供更高的效率
- 存储结构:可以保存大量的数据,高效的内部存储机制,便于查询
- set类型:与hash存储结构彻底相同,仅存储键,不存储值(nil),而且值不容许为空
set存储结构是string类型的无序集合,内部存储时hash存储结构,所以添加、查找、删除的复杂度都是O(1)
添加不重复的数据
sadd key value
获取存储的全部数据
smembers key
删除数据
strem key member1 [member2]
获取集合数据总量
scard key
判断集合中是否包含指定数据
sismember key member
随机获取集合中指定数量的数据
srandmember key [count]
随机获取集合中某个数据并将该数据移出集合
apop key
两个集合的交、并、差集
sinter key1 [key2] sunion key1 [key2] adiff key1 [key2]
求两个集合的交、并、差集并存储到指定集合中
sinterstore destination key1 [key2] sunionstore destination key1 [key2] sdiffstore destination key1 [key2]
将指定数据从原始集合中移动到目标集合中
smove source destination member
set类型不容许有重复数据,若是添加的数据在set中已存在,将只保留一份
set虽然与hash存储结构相同,但没法启用hash中存储值的空间
存储需求:数据排序有利于数据的展现效果,须要提供一种能够根据自身特征进行排序的方式
存储结构:能够保存排序的数据
存储类型:在set的存储结构上添加可排序字段
添加数据
zadd key scorel member [score2 member2]
获取所有数据
zrange key start stop [witchscores] zrevrange key star stop [witchscores]
删除数据
zrem key member [member ...]
按条件查询数据
zrangebyscore key min max [withscores] [limit] zrevrangebyscore key max min [withscores]
条件删除数据
zremrangebyrank key start stop //start stop 表示索引的开始结束位置 zremrangebyscore key min max //min max表示排序的最小到最大位置
获取集合数据数量
zcard key zcount key min max
集合交、并操做
zinterstore destination numkeys key [key ...] zunionstore destination key [key ...]