(1) Redis基本概念
Redis是一个远程内存数据库,它不仅性能强劲,而且还具有复制特性以及为解决问题而生的独一无二的数据模型。Redis提供了5中不同类的数据结构型,各式各样的问题都可以很自然地映射到这些数据结构上;Redis的数据结构致力于帮助用户解决问题,而不会像其他数据库那样,要求用户扭曲问题来适应数据库。除此之外,通过复制、持久化和客户端分片等特性。
优点:Redis是一个可以用来解决的工具,它即拥有其它数据库不具备的数据结构,又拥有内存数据库(这使得Redis的速度非常的快)、远程(这使得Redis可以和多个客户端和服务器进行连接)、持久化(这使得服务器可以在重启之后仍然保持重启之前的数据)和可扩展(通过主从复制和分片)等多个特性,这使得用户可以以熟悉的方式为各种不同的问题构建解决方案。
和其它数据库的比较:
名称 | 类型 | 数据存储选项 | 查询类型 | 附加功能 |
Redis | 使用内存存储的非关系数据库 | 字符串、列表、集合、散列表、有序集合 | 每种数据类型都有自己专属命令,另外还有批量操作和不完全的事务支持 | 发布与订阅,主从复制持久化、脚本(存储过程) |
memcached | 使用内存存储的键值缓存 | 键值之间的映射 | 创建命令、读取命令、更新命令、删除命令以及其他几个命令 | 为提升性能而设的多线程服务器 |
MongoDB | 使用硬盘存储的非关系数据库 | 每个数据库可以包含多个表,每个表可以包含多个无schema的BSON文档 | 创建命令、读取命令、更新命令、删除命令、条件查询命令等 | 支持map-reduce操作主从复制,分片,空间索引 |
Mysql | 关系数据库 | 每个数据库可以包含多个表,每个表可以包含多个行,可以处理多个表的视图;支持空间和第三方扩展 | SELECT、INSERT、UPDATE、DELETE、函数、存储过程 | 支持ACID性质主从复制,由第三方支持的多主复制和主主复制 |
PostgreSQL | 关系数据库 | 每个数据库可以包含多个表,每个表可以包含多个行,可以处理多个表的视图;支持空间和第三方扩展;支持可定制类型 | SELECT、INSERT、UPDATE、DELETE、内置函数、自定义存储过程 | 支持ACID性质主从复制,由第三方支持的多主复制 |
(2) Redis数据类型
结构类型 | 结构存储的值 | 结构的读写能力 |
STRING | 可以是字符串、整数或者浮点数 | 对执行整个字符串或者字符串的其中一部分执行操作;对整数和浮点数自增或者自减操作 |
LIST | 一个链表,链表上每个节点都包含了一个字符串 | 从链表的两端推入或者弹出元素;根据偏移量对链表进行修剪;读取单个或者多个元素;根据值查找或者移除元素 |
SET | 包含字符串的无序收集器,并且被包含的每个字符串都是独一无二,各不相同的 | 添加、获取、移除单个元素;检查一个元素是否存在于集合中;计算交集、并集、差集;从集合里面随机获取元素 |
HASH | 包含键值对的无序散列表 | 添加、获取、移除单个键值对;获取所有键值对 |
ZSET(有序集合) | 字符串成员与浮点数分值之间的有序映射,元素的排列顺序由分值的大小决定 | 添加、获取、移除单个元素;根据分值范围(range)或者成员来获取元素 |
1) STRING(字符串)
基本概念:Redis的STRING和其它编程语言或者其它键值存储提供的字符串非常相似。
基本实例:
键名 值的类型
hello string
word
值
一个STRING示例,键为hello,值为word。
基本命令:
GET:获取存储在给定键中的值
SET:设置存储在给定键中的值
DEL:删除存储在给定键中的值(这个命令可以用于所有的类型)
2) LIST(列表)
基本概念:Redis对链表结构的支持使得它在键值存在的世界中独树一帜。
基本实例:list—key是一个包含3和元素的列表键,注意这里的元素是可以重复
键名 值的类型
list-key list
item
item2
item
列表中包含的元素,相同元素可以重复出现。
基本命令:
RPUSH:将给定值推入列表的右端。
LRANGE:获取列表在给定范围上的所有值。
LINDEX:获取列表在给定位置上的单个元素。
LPOP:从列表的左端弹出一个值,并返回被弹出的值。
3)SET(集合)
基本概念:集合和列表都可以存储多个字符串,他们之间的不同在于,列表可以存储多个相同的字符串,而集合则通过使用散列表来保证自己存储的每个字符串都是各不相同。
基本实例:set-key是一个包含3个元素的集合键
键名 值的类型
set-key set
item2
item
item3
各不相同的元素,无序排列
基本命令:
SADD:将给定元素添加到元素。
SMEMBERS:返回集合包含的所有元素。
STSMEMBER:检查给定元素是否存在于集合中。
SREM:如果给定的元素存在于集合中,那么移除这个元素。
4)HASH(散列)
基本概念:可以存储多个键值对之间的映射。
基本实例:hash-key 是一个包含两个键值对的散列键
hash-key hash
sub_key1 value1
sub_key2 value2
各不相同的键, 与键关联的值
无序排列
基本命令:
HSET:在散列里面关联起给定的键值对。
HGET:获取指定散列键的值。
HGETALL:获取散列包含的所有键值对。
HDEL:如果给定键存在于散列里面,那么移除这个键。
5)ZSET(有序集合)
基本概念:有序集合和散列一样,都是存储键值对有序集合的键被称为成员,每一个成员都是独一无二的;而有序集合的值则被称为分值,分值必须为浮点数。
基本实例:zset—key 是一个包含两个元素的有序集合键
键名 zset
zset-key zset
member1 728
member0 982
成员, 分值,根据数字大小进行排序
根据相关联的分值进行排序
基本命令:
ZADD:将一个带有给定分值的成员添加到有序集合里面。
ZRANGE:根据元素在有序排列中所处的位置,从有序集合里面获取多个元素。
ZRANGEBYSCORE:获取有序集合在给定分值范围内的所有元素。
ZREM:如果给定成员存在有序集合,那么移除这个成员。