Redis
1.0.1 简介
- Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorter set:有序集合)
2.0.1 String (字符串)
- string 是redis最基本的类型,你可以理解成与Memcached 一模一样的类型,一个key对应一个value。
- string 类型是二进制安全的。redis的string可以包含任何数据。比如jpg图片或者序列化的队性。
- string 类型是redis最进本的数据类型,string类型的值最大能存储512MB
2.1.1 string 作用场景
set 创建库和表
set name zhangsan
get 查询库里的表
get name
del 删除库
del name
type 查询数据库字符类型
type name
keys 查询库
keys *
3.0.1 Hash (哈希字典)
- Redis hash 是一个键值(key=>value)对集合
- Redis hash 是一个string类型的field和value的映射表,hash特别适合用于存储对象。
- 每个hash可以存储2的32次方 -1 键值对。
3.1.1 Hash 作用场景
- 键值对集合,即编程语言种的Map类型 适合存储对象,并且可以像数据库种update一个属性一样只修改某一项属性
- 示例:
创建
hmset stu name lisi age 18 sex 男
查看
hget stu name
hget stu age
hget stu sex
- –raw 解决中文乱码问题
redis-cli -h 20.0.0.10 -p 6379 --raw
4.0.1 list (列表)
- Redis列表是简单的字符串列表,按照插入顺序,可以重复,可以添加一个元素到列表的头部(左边)或者尾部
- 列表最多可存储 2 的32 次方 -1 元素
4.1.1 list 作用场景
- 增删快,提供了操作某一段元素的API
- 最新消息排行等功能(比如朋友圈时间线)
- 消息队列
输入Ipush hobby play
显示1
输入Ipush hobby read
显示2
输入Ipush hobby sport
显示3
输入Irange hobby 0 10
显示sport
显示read
显示play
5.0.1 Set (集合)
- Redis 的 Set 是 string 类型的无序集合。
- 集合是通过哈希表实现,所以添加,删除,查找的复杂度都是0(1).
5.1.1 Set 作用场景
1.共同好友
2.利用唯一性,统计访问网站的所有独立ip
3.还有推荐时,根据tag求交集,大于某个阈值就可以
- sadd命令
*添加一个string元素到key对应的set集合种,成功返回1,如果元素已经在集合种返回0.
示例:
输入 sadd color red green yellow
显示3
输入smembers color
显示red yellow green
输入sadd color red
显示0
6.0.1 zset (sorted set: 有序集合)
- Redis zset 和set 一样也是string类型元素的集合,且不允许重复成员。
- 不同的时每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序
- zset的成员是唯一的,但分数(score)却可以重复
6.1.1 zset 作用场景
-
将Set中的元素增加一个权重参数score,元素按score有序排列
-
数据插入集合时,已经进行天然排序
1,排行榜
2,带权重的消息队列 -
zadd命令
-
添加元素到集合,元素在集合中存在则更新对应score
-
示例
zadd color 0 red
zadd color 0 blue
zadd color 1 green
zadd color 1 yellow
zrangebyscore color 0 10
显示 blue red green yellow
zrangebyscore color 0 0
显示 blue red
zrangebyscore color 1 1
显示 green yellow
7.0.1 多数据库概念
- Redis支持多个数据库,并且每个数据库的数据时隔离的不能共享,并且基于单机才有,如果是集群就没有数据库的概念
- Redis是一个字典结构的存储服务器,而实际上一个Redis实例提供了多个用来存储数据的字典,
- 客户端可以指定将数据存储在那个字典中,这与我们熟知的在一个关系数据库实例中可以创建多个数据库类似,
- 所以可以将其中的每个字典都理解成一个独立的数据库。
- 每个数据库对外都是一个从0开始的递增数字命名,Redis默认支持16个数据库(可以通过配置文件支持更多,无上限),
- 可以通过配置databases来修改这一数字,客户端与Redis建立连接后会自动选择0号数据库,
- 不过可以随时使用SELECT命令更换数据库,如果选择1号数据库:
- 示例
select 1
set name zhangsan
select 2
set name zhangsan
清空所有数据库数据
flushall
gwtname
8.0.1 key常规管理
- 验证key是否存在
set name zhangsan
exists name
exists names
- 重命名 rename
rename name na
get na
- 设置超时时间 pexpire (单位:毫秒)
PEXPIRE na 3000
get na
- 查看剩余时间PTTL(单位:毫秒)
PEXPIRE name 30000
PTTL name
- 取消超时时间
set name zhangsan
PEXPIRE name 50000
PTTL name
PERSIST name
PTTL name
get name
- 查看类型 type
lpush color red blue
TYPE color
set name zhangsan
TYPE name
- 随机返回key RANDOMKEY
mset age 18 score 88 sex boy
RANDOMKEY
RANDOMKEY
RANDOMKEY
- 查看所有 key
keys *
- 数据迁移数据库 move
move age 1
select 1
get age