redis的数据类型
1,概述
使用Redis进行应用设计和开发的一个核心概念是数据类型。
与关系数据库不同,在Redis中不存在需要我们担心的表,
在使用Redis进行应用设计和开发时,我们首先应该考虑的是Redis原生支持的哪种数据类型阳适合我们的应该场景,
此外,我们无法像在关系数据库中那样,使用sql来操作Redis中的数据,
相反,我们需要直接使用API发送数据反对应的命令,来操作想要操作的数据
2,字符串类型
字符串类型是编程语言和应用程序中最常见和最有用的数据类型,也是Redis的基本数据类型之一,
事实上,Redis中所有键都必须是字符串。
3,list数据类型
列表是应用我只是应该程序开发中非常有用的数据类型之一,列表能存在一组对象,
因此它也可以被用于栈或者队列,
在Redis中,与键相关的联的值可以是字符串组成的列表,Redis中的列表更像是数据结构中的双向链表。
4,hash数据类型
哈希表示字段和值之间的映射关系,与JAVA中的Map类似,
Redis数据集本身就可以看做一个哈希,其中字符串类型的键关联到如字符串和列表之类的数据对象,
而Redis的数据对象也可以再次使用哈希,其字段和值必须 是字符串。
5,set数据类型
集合类型是由唯一,无序对象组成的集合(collection).它经常用于测试某个成员是集合中,
重复项删除和集合运算(求并,交,差集),
Redis的值对象可以是字符串集合。
6,zset(sortset)数据类型
有序集合是一个类似于set但是更复杂的数据类型,
单词sorted意为着这种集合中的每个元素都有一个可用于排序的权重,
并且我们可以按顺序从集合中得到元素在某些需要一个保持数据有序的场景中,使用这种原生的序的特性是很方便的。
相关知识串讲
1,单进程单线程
采用多路 I/O 复用技术可以让单个线程高效的处理多个连接请求(尽量减少网络IO的时间消耗)
why?
多线程处理可能涉及到锁
多线程处理会涉及到线程切换而消耗CPU
单进程不存在线程安全问题
缺点:
无法发挥多核CPU性能,不过可以通过在单机开多个Redis实例来完善
2,默认16个兄弟一起站台
默认16个数据库,类似数组下表从零开始,初始默认使用零号库
3,切换数据库命令
select命令切换数据库
4,常用基本命令
dbsize查看当前数据库的key的数量
flushdb:清空当前库
Flushall;通杀全部库
5,其它说明
统一密码管理,16个库都是同样密码,要么都OK要么一个也连接不上
Redis索引都是从零开始
相关命令详解
官网命令列表:
http://www.redis.net.cn/order/
官方文档:
http://redisdoc.com/
常用命令:
keys * 获取所有的key select 0 选择第一个库 move myString 1 将当前的数据库key移动到某个数据库,目标库有,则不能移动 flushdb 清除指定库 randomkey 从当前数据库中随机返回 type key 类型 del key1 删除key exists key 判断是否存在key expire key 10 10过期 pexpire key 1000毫秒 persist key 删除过期时间 ttl key 查看还有多少秒过期,-1表示永不过期,-2表示已过期
string类型相关命令
set name cxx get name getrange name 0 -1 字符串分段 0 -1是全部 0 -2 ==n-1 getset name new_cxx 设置值,返回旧值 mset key1 key2 批量设置 mget key1 key2 批量获取 setnx key value 不存在就插入(not exists) setrange key index value 从index开始替换value incr age 递增 incrby age 10 递增 decr age 递减 decrby age 10 递减 incrbyfloat 增减浮点数 append 追加 strlen 长度 object encoding key 得到key 的类型
string里面有三种编码 int 用于能够副作用64位有符号整数表示的字符串 embstr 用于长度小于或等于44字节 Redis3.x中是39字节,这种类型的编码在内存使用时性能更好 raw 用于长度大于44字节的
list
lpush mylist a b c 左插入 rpush mylist x y z 右插入 lrange mylist 0 -1 取出数据集合 0 -1是取出所有 0 1取第第一个和第二个 lpop mylist 弹出集合最后一个元素 弹出之后就没有了哦 rpop mylist 弹出第一个元素 弹出之后就没有了哦 llen mylist 长度 lrem mylist count value 删除 |-COUNT 的值可以是以下几种: |--count > 0 : 从表头开始向表尾搜索,移除与 VALUE 相等的元素,数量为 COUNT 。 |--count < 0 : 从表尾开始向表头搜索,移除与 VALUE 相等的元素,数量为 COUNT 的绝对值。 |--count = 0 : 移除表中所有与 VALUE 相等的值。 lindex mylist 2 指定索引的值 lset mylist 2 n 索引设值 ltrim mylist 0 4 |--对一个列表进行修剪(trim),就是说,让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除。 下标 0 表示列表的第一个元素,以 1 表示列表的第二个元素,以此类推。 你也可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,以此类推。 linsert mylist before a 插入 linsert mylist after a 插入 |--命令用于在列表的元素前或者后插入元素。 当指定元素不存在于列表中时,不执行任何操作。 当列表不存在时,被视为空列表,不执行任何操作。 如果 key 不是列表类型,返回一个错误。 rpoplpush list list2 转移列表的数据 |--命令用于移除列表的最后一个元素,并将该元素添加到另一个列表并返回。
Hash
hset myhash name cxx |--命令用于为哈希表中的字段赋值 。 |--如果哈希表不存在,一个新的哈希表被创建并进行 HSET 操作。 |--如果字段已经存在于哈希表中,旧值将被覆盖。 hget myhash name hmset myhash name cxx age 25 note "i am notes" hmget myhash name age note hgetall myhash 获取所有的 hexists myhash name 是否存在 hsetnx myhash score 100 设置不存在的 如果存在,不做处理 hincrby myhash id 1 递增 hdel myhash name 删除 hkeys myhash 只取key hvals myhash 只取value hlen myhash 长度
Set
sadd myset redis smembers myset 数据集合 srem myset set1 删除 sismember myset set1 判断元素是否在集合中 scard key_name 个数 sdiff | sinter | sunion 操作:集合间运算:差集 | 交集 | 并集 srandmember 随机获取集合中的元素 spop 从集合中弹出一个元素
Zset
zadd zset 1 one zadd zset 2 two zadd zset 3 three zincrby zset 1 one 增长分数 zscore zset two 获取分数 zrange zset 0 -1 withscores 范围值 zrangebyscore zset 10 25 withscores 指定范围的值 zrangebyscore zset 10 25 withscores limit 1 2 分页 Zrevrangebyscore zset 10 25 withscores 指定范围的值 zcard zset 元素数量 Zcount zset 获得指定分数范围内的元素个数 Zrem zset one two 删除一个或多个元素 Zremrangebyrank zset 0 1 按照排名范围删除元素 Zremrangebyscore zset 0 1 按照分数范围删除元素 Zrank zset 0 -1 分数最小的元素排名为0 Zrevrank zset 0 -1 分数最大的元素排名为0 Zinterstore zunionstore rank:last_week 7 rank:20150323 rank:20150324 rank:20150325 weights 1 1 1 1 1 1 1