1976 2019-02-10 2021-03-14
前言:Redis实战第一章。
一、Redis简介
Redis是一个速度非常快的非关系数据库(no-relational database),它可以存储键(key)与5种不同类型的值(value)之间的映射(mapping),可以将存储在内存的键值对持久化到硬盘,可以使用复制特性来扩展读性能,还可以使用客户端分片来扩展写性能,接下来的几节将分别介绍Redis的这几个特性。
1、与其他数据库的对比
下面这个表展示了它们之间的区别。
名称 | 类型 | 数据存储选项 | 查询类型 | 附加功能 |
---|---|---|---|---|
Redis | 使用内存存储的非关系数据库 | 字符串、列表、集合、散列、有序集合 | 每种数据类型都有自己的专属命令,另外还有批量操作和不完全的事务支持 | 发布与订阅,主从复制,持久化,脚本 |
Memcached | 使用内存存储的键值缓存 | 键值之间的映射 | 创建命令、读取命令、更新命令、删除命令以及其他几个命令 | 为提升性能而设的多线程服务器 |
Mysql | 关系数据库 | 每个数据库可以包含多个表,每个表可以包含多个行;可以处理多个表的视图;支持空间和第三方扩展 | select、insert、update、delete、函数、存储过程 | 支持ACID性质,主从复制和主主复制 |
MongoDB | 使用硬盘存储的非关系文档存储 | 每个数据库可以包含多个表,每个表可以包含多个五schema的bson文档 | 创建命令、读取命令、更新命令、删除命令、条件查询命令等 | 支持map-reduce操作,主从复制,分片,空间索引 |
2、使用Redis的理由
这一部分,我觉得还是通过阅读后面几节后再来总结比较好。先行跳过。
二、Redis数据结构
Redis可以存储键与5中不同数据结构类型之间的映射,如下
结构类型 | 结构存储的值 | 结构的读写能力 |
---|---|---|
STRING | 可以是字符串、整数或者浮点数 | 对整个字符串或字符串的其中一部分执行操作;对整数和浮点数执行自增或者自减操作 |
LIST | 一个链表,链表上的每个节点都包含了一个字符串 | 从链表的两端推入或弹出元素;根据偏移量对链表进行修建;读取单个或者多个元素;根据值查找或者移除元素 |
SET | 包含字符串的无序收集器,并且被包含的每个字符串都是独一无二、各不相同的 | 添加、获取、移除单个元素;检查一个元素是否存在于集合中;计算交集、并集、差集;从集合里面随机获取元素 |
HASH | 包含键值对的无序散列表 | 添加、获取、移除单个键值对;获取所有键值对 |
ZSET | 字符串成员与浮点数分值之间的有序映射,元素的排列顺序由分值大小决定 | 添加、获取,删除单个元素;根据分值范围或者成员来获取元素 |
完整的中文API文档可参考这里。
1、字符串
Redis的字符串和其他编程语言或者其他键值对存储提供的字符串非常相似。下面是一些基本的命令和示例
命令 | 行为 |
---|---|
get | 获取存储在给定键的值 |
set | 设置存储在给定键的值 |
del | 删除存储在给定键的值(这个命令使用于所有类型) |
hk@hk-pc:~$ redis-cli
127.0.0.1:6379> set hello world
OK
127.0.0.1:6379> get hello
"world"
127.0.0.1:6379> get hell
(nil)
127.0.0.1:6379> del hello
(integer) 1
127.0.0.1:6379> get hello
(nil)
2、列表
Redis列表可执行的操作和很多编程语言里面的列表操作非常相似:lpush命令和rpush命令分别用于将元素推入列表的左端和右端。lpop和rpop命令分别用于从列表的左端和右端弹出元素;lindex命令用于获取列表在给定位置上的一个元素;lrange命令用于获取列表在给定的范围上的所有元素。下面是一些基本的命令和示例
命令 | 行为 |
---|---|
lpush | 将给定值推入列表的右端 |
lrange | 获取列表在给定范围上的所有值 |
lindex | 获取列表在给定位置上的单个元素 |
lpop | 从列表的左端弹出一个值,并返回被弹出的值 |
127.0.0.1:6379> del list-key
(integer) 1
127.0.0.1:6379> rpush list-key item
(integer) 1
127.0.0.1:6379> rpush list-key item2
(integer) 2
127.0.0.1:6379> rpush list-key item
(integer) 3
127.0.0.1:6379> lrange list-key 0 -1
1) "item"
2) "item2"
3) "item"
127.0.0.1:6379> lindex list-key 1
"item2"
127.0.0.1:6379> lpop list-key
"item"
127.0.0.1:6379> lrange list-key 0 -1
1) "item2"
2) "item"
3、集合
Redis的集合和列表都可以存储多个字符串,它们之间的不同之处在于,列表可以存储多个相同的字符串,而集合则通过使用散列来保证自己存储的每个字符串都是各不相同的(这些散列表只有键,但没有与键相关联的值)。
因为Redis的集合使用无序方式存储元素,用户可以使用sadd命令将元素添加到集合,或者使用srem命令从集合里面移除元素。另外还可以通过sismember命令快速地检查一个元素是否已经存在于集合中,或者使用smembers命令获取包含的所有元素。下面是一些基本的命令和示例
命令 | 行为 |
---|---|
sadd | 将给定元素添加到集合 |
smembers | 返回集合包含的所有元素 |
sismember | 检查给定元素是否存在于集合中 |
srem | 如果给定的元素存在于集合中,那么移除这个元素 |
127.0.0.1:6379> del set-key
(integer) 1
127.0.0.1:6379> sadd set-key item
(integer) 1
127.0.0.1:6379> sadd set-key item2
(integer) 1
127.0.0.1:6379> sadd set-key item3
(integer) 1
127.0.0.1:6379> sadd set-key item
(integer) 0
127.0.0.1:6379> smembers set-key
1) "item"
2) "item3"
3) "item2"
127.0.0.1:6379> sismember set-key item4
(integer) 0
127.0.0.1:6379> sismember set-key item
(integer) 1
127.0.0.1:6379> srem set-key item2
(integer) 1
127.0.0.1:6379> srem set-key item2
(integer) 0
127.0.0.1:6379> smembers set-key
1) "item"
2) "item3"
4、散列
Redis的散列可以存储多个键值对之间的映射。和字符串一样,散列存储的值既可以是字符串又可以是数字,并且用户同样可以对散列存储的数字值执行自增或自减操作。
散列在很多方面就像是一个微缩版的Redis,不少字符串命令都有相应的散列版本。下面是一些基本的命令和示例
命令 | 行为 |
---|---|
hset | 在散列里面关联给定的键值对 |
hget | 获取指定散列键的值 |
hgetall | 获取散列包含的所有键值对 |
hdel | 如果给定键存在于散列里面,那么移除这个键 |
127.0.0.1:6379> del hash-key
(integer) 1
127.0.0.1:6379> hset hash-key sub-key1 value1
(integer) 1
127.0.0.1:6379> hset hash-key sub-key2 value2
(integer) 1
127.0.0.1:6379> hset hash-key sub-key1 value1
(integer) 0
127.0.0.1:6379> hgetall hash-key
1) "sub-key1"
2) "value1"
3) "sub-key2"
4) "value2"
127.0.0.1:6379> hdel hash-key sub-key2
(integer) 1
127.0.0.1:6379> hdel hash-key sub-key2
(integer) 0
127.0.0.1:6379> hget hash-key sub-key1
"value1"
127.0.0.1:6379> hgetall hash-key
1) "sub-key1"
2) "value1"
5、有序集合
有序集合和散列一样,都用于存储键值对:有序集合的键被称为成员(member),每个成员都是各不相同的;而有序结合的值则被称为分值(score),分值必须为浮点数。有序集合是Redis里面唯一一个既可以根据成员访问元素(这一点和散列一样),又可以根据分值以及分值的排列顺序来访问元素的结构。下面是一些基本的命令和示例
命令 | 行为 |
---|---|
zadd | 将一个带有给定分值的成员添加到有序集合里面 |
zrange | 根据元素在有序排列中所处的位置,从有序集合里面获取多个元素 |
zrangebyscore | 获取有序集合在给定分值范围内的所有元素 |
zrem | 如果给定成员存在于有序集合,那么移除这个成员 |
127.0.0.1:6379> del zset-key
(integer) 1
127.0.0.1:6379> zadd zset-key 728 member1
(integer) 1
127.0.0.1:6379> zadd zset-key 982 member0
(integer) 1
127.0.0.1:6379> zadd zset-key 982 member0
(integer) 0
127.0.0.1:6379> zrange zset-key 0 -1 withscores
1) "member1"
2) "728"
3) "member0"
4) "982"
127.0.0.1:6379> zrangebysocre zset-key 0 800 withscores
(error) ERR unknown command 'zrangebysocre'
127.0.0.1:6379> zrangebyscore zset-key 0 800 withscores
1) "member1"
2) "728"
127.0.0.1:6379> zrem zset-key member1
(integer) 1
127.0.0.1:6379> zrem zset-key member1
(integer) 0
127.0.0.1:6379> zrange zset-key 0 -1 withscores
1) "member0"
2) "982"
未完待续....
总访问次数: 207次, 一般般帅 创建于 2019-02-10, 最后更新于 2021-03-14
欢迎关注微信公众号,第一时间掌握最新动态!