1. NoSQL:一类新出现的数据库 非关系型数据库(not only sql)
1.1 不支持SQL语法
2.1 存储结构跟传统关系型数据库中的那种关系表完全不同,nosql中存储的数据都是Key-Value形式
3.1 NoSQL的世界中没有一种通用的语言,每种nosql数据库都有自己的api和语法,以及擅长的业务场景
4.1 Nosql 常见产品种类:Mongodb,Redis,Hbase hadoop,Cassandra hadoop
2. redis
2.1 简介:
• Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。从2010年3月15日起,Redis的开发工作由VMware主持。从2013年5月开始,Redis的开发由Pivotal赞助。
• Redis是 NoSQL技术阵营中的一员,它通过多种键值数据类型来适应不同场景下的存储需求,借助一些高层级的接口使用其可以胜任,如缓存、队列系统的不同角色
2.2 redis 特性:
• Redis 与其他 key - value 缓存产品有以下三个特点:
• Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
• Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
• Redis支持数据的备份,即master-slave模式的数据备份。
2.3 Redis 优势
• 性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。
• 丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。
• 原子 – Redis的所有操作都是原子性的,同时Redis还支持对几个操作全并后的原子性执行。
丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性
2.4 redis应用场景
• 用来做缓存(ehcache/memcached)——redis的所有数据是放在内存中的(内存数据库)
• 可以在某些特定应用场景下替代传统数据库——比如社交类的应用
• 在一些大型系统中,巧妙地实现一些特定的功能:session共享、购物车
• 只要你有丰富的想象力,redis可以用在可以给你无限的惊喜…….
2.5 redis 数据结构
• redis是key-value的数据结构,每条数据都是⼀个键值对
• 键的类型是字符串
• 注意:键不能重复

• 值的类型分为五种:
o 字符串string
o 哈希hash
o 列表list
o 集合set
o 有序集合zset
(中⽂官⽹查看命令⽂档http://redis.cn/commands.html)
2.5.1常用键操作指令
(1) 查找键,参数⽀持正则表达式
keys pattern
// 例:查看所有键
keys *
// 例:查看名称中包含a的键
keys a*
(2)判断键是否存在,如果存在返回1,不存在返回0
exists key1
(3) 查看键对应的value的类型
type key
// 例:查看键a1的值类型,为redis⽀持的五种类型中的⼀种
type a1

(4) 删除键及对应的值
del key1 key2 ...
(5)设置过期时间,以秒为单位。如果没有指定过期时间则⼀直存在,直到使⽤DEL移除
expire key seconds
查看有效时间,以秒为单位.
-当 key 不存在时,返回 -2
-当 key 存在但没有设置剩余生存时间时,返回 -1 。
-否则,以秒为单位,返回 key 的剩余生存时间。
ttl key

2.5.2 String类型
• 字符串类型是Redis中最为基础的数据存储类型,该类型可以接受任何格式的数据,如JPEG图像数据或Json对象描述信息等。在Redis中字符串类型的Value最多可以容纳的数据长度是512M。
(1).保存:如果设置的键不存在则为添加,如果设置的键已经存在则修改
set key value. //设置键值
• 设置键值及过期时间,以秒为单位
setex key seconds value
例:设置键为aa值为aa过期时间为3秒的数据
--setex aa 3 aa
• 设置多个键值
mset key1 value1 key2 value2 ...
• 追加值
append key value
//例4:向键为a1中追加值' 真棒'
---append 'a1' '真棒'
中文乱码问题的解决
a) 退出redis客户端
Exit
b) 再次进图redis客户端
Redis-cli --raw
(2).获取:根据键获取值,如果不存在此键则返回nil
get key
// 例:获取键'name'的值
get name
• 根据多个键获取多个值
mget key1 key2 ...
// 例:获取键a1、a2、a3'的值
--mget a1 a2 a3
(3).删除: 直接调用删除键指令
del key1 key2 ...
2.5.3Hash类型
• hash⽤于存储对象,对象的结构为属性、值
• 值的类型为string
(1).增加,修改
// 设置单个属性(字段)
hset key field value
例:设置键 user的属性name为111
--het user name 111
//设置多个属性
hmset key field1 value1 field2 value2 ...
// 例:设置键u2的属性name为111、属性age为11
hmset u2 name 111 age 11
(2).获取
• 获取指定键所有的属性
hkeys key

• 获取指定属性的值
hget key field
• 获取多个属性的值
hmget keys field1 field2....
• 所有属性的值
hvals key
• 获取一个hash有多少个属性
hlen key
(3).删除:删除整个hash键及值,使⽤del命令
• 删除属性,属性对应的值会被⼀起删除
hdel key field1 field2 ...
2.5.4 List类型
• 列表的元素类型为string
• 按照插⼊顺序排序
(1).增加,修改
• 在左侧插⼊数据
lpush key value1 value2 ...
//例:从键为'a1'的列表左侧加⼊数据a 、 b 、c
lpush a1 a b c // 结果:c,b,a
• 在右侧插⼊数据
rpush key value1 value2 ...
//例:从键为'a1'的列表左侧加⼊数据a 、 b 、c
rpush a1 a b c // 结果:a,b,c
• 在指定元素的前或后插⼊新元素
linsert key before或after 现有元素 新元素
// 例:在键为'a1'的列表中元素'b'前加⼊'3'
linsert a1 before b 3
• 设置指定索引位置的元素值
lset key index value
• 索引从左侧开始,第⼀个元素为0
• 索引可以是负数,表示尾部开始计数,如-1表示最后⼀个元素
(2).获取
lrange key start stop
• 返回列表⾥指定范围内的元素
• start、stop为元素的下标索引
• 索引从左侧开始,第⼀个元素为0
• 索引可以是负数,表示从尾部开始计数,如-1表示最后⼀个元素
(3).删除
删除指定元素
lrem key count value
o 将列表中前count次出现的值为value的元素移除
o count > 0: 从头往尾移除
o count < 0: 从尾往头移除
o count = 0: 移除所有
2.5.5 set类型
• ⽆序集合
• 元素为string类型
• 元素具有唯⼀性,不重复
• 说明:对于集合没有修改操作
(1).增加
sadd key member1 member2 ...
• 例:向键'a3'的集合中添加元素'zhangsan'、'lisi'、'wangwu'
sadd a3 zhangsan sili wangwu
(2).获取: 获取所有元素
smembers key
(3). 删除:删除指定元素
srem key value
// 例:删除键'a3'的集合中元素'wangwu'
srem a3 wangwu
2.5.6 zset类型
• sorted set,有序集合
• 元素为string类型
• 元素具有唯⼀性,不重复
• 每个元素都会关联⼀个double类型的score,表示权重,通过权重将元素从⼩到⼤排序
• 说明:没有修改操作
(1).增加
zadd key score1 member1 score2 member2 ...
// 例:向键'a4'的集合中添加元素'lisi'、'wangwu'、'zhaoliu'、'zhangsan',权重分别为4、5、6、3
--zadd a4 4 lisi 5 wangwu 6 zhaoliu 3 zhangsan
(2).获取
zrange key start stop
• 返回指定范围内的元素
• start、stop为元素的下标索引
• 索引从左侧开始,第⼀个元素为0
• 索引可以是负数,表示从尾部开始计数,如-1表示最后⼀个元素
• 例:获取键'a4'的集合中所有元素
zrange a4 0 -1

• 返回score值在min和max之间的成员
zrangebyscore key min max
例:获取键'a4'的集合中权限值在5和6之间的成员
zrangebyscore a4 5 6

• 返回成员member的score值
zscore key member
例:获取键'a4'的集合中元素'zhangsan'的权重
zscore a4 zhangsan

(3).删除
• 删除指定元素
zrem key member1 member2 ...
• 删除权重在指定范围的元素
zremrangebyscore key min max
例:删除集合'a4'中权限在5、6之间的元素
zremrangebyscore a4 5 6

网友评论