nosql介绍
NoSQL:一类新出现的数据库(not only sql)
泛指非关系型的数据库
不支持SQL语法
存储结构跟传统关系型数据库中的那种关系表完全不同,nosql中存储的数据都是KV形式
NoSQL的世界中没有一种通用的语言,每种nosql数据库都有自己的api和语法,以及擅长的业务场景
NoSQL中的产品种类相当多:
Redis
Mongodb
Hbase hadoop
Cassandra hadoop
NoSQL和SQL数据库的比较:
适用场景不同:sql数据库适合用于关系特别复杂的数据查询场景,nosql反之
事务 特性的支持:sql对事务的支持非常完善,而nosql基本不支持事务
两者在不断地取长补短,呈现融合趋势
Redis简介
Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。从2010年3月15日起,Redis的开发工作由VMware主持。从2013年5月开始,Redis的开发由Pivotal赞助。
Redis是 NoSQL技术阵营中的一员,它通过多种键值数据类型来适应不同场景下的存储需求,借助一些高层级的接口使用其可以胜任,如缓存、队列系统的不同角色
Redis特性
Redis 与其他 key - value 缓存产品有以下三个特点:
Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
Redis支持数据的备份,即master-slave模式的数据备份。
Redis 优势
性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。
丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。
原子 – Redis的所有操作都是原子性的,同时Redis还支持对几个操作全并后的原子性执行。
丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性。
string类型
字符串类型是 Redis 中最为基础的数据存储类型,它在 Redis 中是二进制安全的,这便意味着该类型可以接受任何格式的数据,如JPEG图像数据或Json对象描述信息等。在Redis中字符串类型的Value最多可以容纳的数据长度是512M。
保存
如果设置的键不存在则为添加,如果设置的键已经存在则修改
设置键值
set key value
设置键值及过期时间,以秒为单位
setex key seconds value
例2:设置键为aa值为aa过期时间为3秒的数据
setex aa 3 aa
设置多个键值
mset key1 value1 key2 value2 ...
例3:设置键为a1值为python、键为a2值为java、键为a3值为c
mset a1 python a2 java a3 c
追加值
append key value
例4:向键为a1中追加值haha
append a1 haha
获取
获取:根据键获取值,如果不存在此键则返回nil
get key
例5:获取键name的值
get name
根据多个键获取多个值
mget key1 key2 ...
例6:获取键a1、a2、a3的值
mget a1 a2 a3
键命令
查找键,参数⽀持正则表达式
keys pattern
例1:查看所有键
keys *
例2:查看名称中包含a的键
keys a*
判断键是否存在,如果存在返回1,不存在返回0
exists key1
例3:判断键a1是否存在
exists a1
查看键对应的value的类型
type key
例4:查看键a1的值类型,为redis⽀持的五种类型中的⼀种
type a1
删除键及对应的值
del key1 key2 ...
例5:删除键a2、a3
del a2 a3
设置过期时间,以秒为单位
如果没有指定过期时间则⼀直存在,直到使⽤DEL移除
expire key seconds
例6:设置键a1的过期时间为3秒
expire a1 3
查看有效时间,以秒为单位
ttl key
例7:查看键bb的有效时间
ttl bb
hash类型
hash⽤于存储对象,对象的结构为属性、值
值的类型为string
增加、修改
设置单个属性
hset key field value
例1:设置键 user的属性name为itheima
hset user name itheima
设置多个属性
hmset key field1 value1 field2 value2 ...
例2:设置键u2的属性name为itcast、属性age为11
hmset u2 name itcast age 11
获取
获取指定键所有的属性
hkeys key
例3:获取键u2的所有属性
hkeys u2
获取⼀个属性的值
hget key field
例4:获取键u2属性name的值
hget u2 name
获取多个属性的值
hmget key field1 field2 ...
例5:获取键u2属性name、age的值
hmget u2 name age
获取所有属性的值
hvals key
例6:获取键u2所有属性的值
hvals u2
删除
删除整个hash键及值,使⽤del命令
删除属性,属性对应的值会被⼀起删除
hdel key field1 field2 ...
例7:删除键u2的属性age
hdel u2 age
可能出现的错误
MISCONF Redis is configured to save RDB snapshots, but is currently not able to persist on disk. Commands that may modify the data set are disabled. Please check Redis logs for details about the error.
Redis被配置为保存数据库快照,但它目前不能持久化到硬盘。用来修改集合数据的命令不能用
原因:
强制关闭Redis快照导致不能持久化。
解决方案:
运行config set stop-writes-on-bgsave-error no 命令后,关闭配置项stop-writes-on-bgsave-error解决该问题。
list类型
列表的元素类型为string
按照插⼊顺序排序
增加
在左侧插⼊数据
lpush key value1 value2 ...
例1:从键为a1的列表左侧加⼊数据a 、 b 、c
lpush a1 a b c
在右侧插⼊数据
rpush key value1 value2 ...
例2:从键为a1的列表右侧加⼊数据0、1
rpush a1 0 1
在指定元素的前或后插⼊新元素
linsert key before或after 现有元素 新元素
例3:在键为a1的列表中元素b前加⼊3
linsert a1 before b 3
获取
返回列表⾥指定范围内的元素
start、stop为元素的下标索引
索引从左侧开始,第⼀个元素为0
索引可以是负数,表示从尾部开始计数,如-1表示最后⼀个元素
lrange key start stop
例4:获取键为a1的列表所有元素
lrange a1 0 -1
设置指定索引位置的元素值
索引从左侧开始,第⼀个元素为0
索引可以是负数,表示尾部开始计数,如-1表示最后⼀个元素
lset key index value
例5:修改键为a1的列表中下标为1的元素值为z
lset a 1 z
删除
删除指定元素
将列表中前count次出现的值为value的元素移除
count > 0: 从头往尾移除
count < 0: 从尾往头移除
count = 0: 移除所有
lrem key count value
例6.1:向列表a2中加⼊元素a、b、a、b、a、b
lpush a2 a b a b a b
例6.2:从a2列表右侧开始删除2个b
lrem a2 -2 b
例6.3:查看列表a2的所有元素
lrange a2 0 -1
baaa
set类型
⽆序集合
元素为string类型
元素具有唯⼀性,不重复
说明:对于集合没有修改操作
增加
添加元素
sadd key member1 member2 ...
例1:向键a3的集合中添加元素zhangsan、lisi、wangwu
sadd a3 zhangsan sili wangwu
获取
返回所有的元素
smembers key
例2:获取键a3的集合中所有元素
smembers a3
删除
删除指定元素
srem key
例3:删除键a3的集合中元素wangwu
srem a3 wangwu