主要内容:
1.Redis简介
2.Redis与其他软件的相同之处与不同之处
3.Redis的用法Redis简介
redis是一个速度非常快的非关系数据库,可以存储键key 与5种不同类型的值之间的映射,可以将存储在内存的键值对数据持久化到硬盘,可以使用复制特性扩展读性能,还可以使用客户端分片来扩展写性能。
1.Redis与其他数据库和软件的对比
名称 | 类型 | 数据存储选项 | 查询类型 | 附加功能 |
---|---|---|---|---|
Redis | 使用内存存储的非关系型数据库 | 字符串、列表、集合、散列、有序集合 | 每种数据类型都有自己的专属命令,另外还有批量操作和不完全的事务支持 | 发布与订阅,主从复制,持久化,脚本 |
memcached | 使用内存存储的键值缓存 | 键值之间的映射 | 创建命令、读取命 令、更新命令、删除命令以及其他几个命令 | 为提升性能而设的多线程服务器 |
MySql | 关系数据库 | 每个数据库可以包含多个表,每个表可以包含多个行,可以处理多个表的视图,支持空间和第三方扩展 | select、insert、update、delete、函数、存储过程 | 支持ACID性质、主从复制和主主复制 |
MongoDB | 使用硬盘存储的非关系文档存储 | 每个数据库可以包含多个表,每个表可以包含多个无schema的BSON文档 | 创建命令,读取命令,更新命令,删除命令,条件查询命令等 | 支持map-reduce操作,主从复制,分片,空间索引 |
2.Redis数据结构简介
5种数据结构类型分别是:String、LIST、SET、HASH、ZSET
数据类型 | 结构存储的值 | 结构的读写能力 |
---|---|---|
STRING | 可以是字符串、整数或者浮点数 | 对整个字符串或者字符串的其中一部分执行操作,对整数和浮点数执行自增或者自减 |
LIST | 一个链表、链表上的每个节点包含一个字符串 | 从链表的两端推入或者弹出元素,根据偏移量对链表进行修剪,读取单个或者多个元素,根据值查找或者移除元素 |
SET | 包含字符串的无序收集器,并且被包含的每个字符串都是独一无二,各不相同的 | 添加、获取、移除单个元素,检查一个元素是否存在于集合中,计算交集、并 集、差集,从集合中随机获取元素 |
HASH | 包含键值的无序散列表 | 添加、获取、移除单个键值对,获取所有键值对 |
ZSET | 字符串成员与浮点数分值之间的有序映射,元素的排序由分值的大小决定 | 添加、获取、删除单个元素,根据分值范围或者成员来获取元素 |
Java代码可以从https://github.com/josiahcarlson/redis-in-action/tree/master/java下载
字符串STRING常用的命令:
GET :获取存储在给定键中的值
SET : 设置存储在给定键中的值
DEL:删除存储在给定键中的值
一个字符串示例,键为hello,值为world
列表LIST常用的命令
LPUSH:将元素推入列表的左端
RPUSH:将元素推入列表的右端
LPOP:从列表的左端弹出元素
RPOP:从列表的右端弹出元素
LINDEX:获取列表再给定位置上的单个元素
LRANGE:获取列表再给定范围上的所有元素
SET集合的命令
SADD:将给定元素添加到集合
SMEMBERS:返回集合包含的所有元素
SISMEMBER:检查给定元素是否存在于集合中
SREM:如果给定的元素存在于集合中,则移除这个元素
HASH常用的命令
HSET:在散列里面关联起给定的键值对
HGET:获取指定散列键的值
HGETALL:获取散列包含的所有键值对
HDEL:如果给定键存在于散列里面,那么移除这个键
有序集合ZSET常用的命令
ZADD:将一个带有给定分值的成员添加到有序集合里面
ZRANGE:根据元素在有序列表中所处的位置,从有序集合里面获取多个元素
ZRANFEBYSCORE:获取有序集合在给定分值范围内的所有元素
ZREM:如果给定成员存在于有序集合,那么移除这个成员