复习总结07:Redis

来源:互联网 发布:《java编程语言》 编辑:程序博客网 时间:2024/05/22 05:03
一、Redis概述:
Redis是一个开源,先进的key-value存储,并用于构建高性能,可扩展的应用程序的完美解决方案。
Redis数据库完全在内存中,使用磁盘仅用于持久性。 
相比许多键值数据存储,Redis拥有一套较为丰富的数据类型
Redis可以将数据复制到任意数量的从服务器。 

Redis 优势 
异常快速:Redis的速度非常快,每秒能执行约11万集合,每秒约81000+条记录。 
支持丰富的数据类型:Redis支持字符串、列表、集合、有序集合散列数据类型,这使得它非常容易解决各种各样的问题。 
操作都是原子性:所有Redis操作是原子的,这保证了如果两个客户端同时访问的Redis服务器将获得更新后的值
多功能实用工具:Redis是一个多实用的工具,可以在多个用例如缓存,消息,队列使用(Redis原生支持发布/订阅),任何短暂的数据,应用程序,如Web应用程序会话,网页命中计数等。 

二、
Redis常用五种数据类型:string,hash,list,set,zset(sorted set).

1.String类型
String是最简单的类型,一个key对应一个value
String类型的数据最大1G。 
String类型的值可以被视作integer,从而可以让“INCR”命令族操作(incrby、decr、decrby),这种情况下,该integer的值限制在64位有符号数。 
在list、set和zset中包含的独立的元素类型都是redis String类型。

2.List类型
链表类型,主要功能是push、pop、获取一个范围的所有值等。其中的key可以理解为链表的名字。
在Redis中,list就是Redis String的列表,按照插入顺序排序。比如使用LPUSH命令在list头插入一个元素,使用RPUSH命令在list的尾插入一个元素。当这两个命令之一作用于一个空的key时,一个新的list就创建出来了。
List的最大长度是2^32-1个元素。

3.Set类型
集合,和数学中的集合概念相似。操作中的key理解为集合的名字。
在Redis中,set就是Redis String的无序集合,不允许有重复元素。
Set的最大元素数是2^32-1。
Redis中对set的操作还有交集、并集、差集等。

4.ZSet(Sorted Set)类型
Zset是set的一个升级版本,在set的基础上增加了一个顺序属性,这一属性在添加修改元素时可以指定,每次指定后zset会自动安装指定值重新调整顺序。可以理解为一张表,一列存value,一列存顺序。操作中的key理解为zset的名字。
Zset的最大元素数是2^32-1。
对于已经有序的zset,仍然可以使用SORT命令,通过指定ASC|DESC参数对其进行排序。

5.hash类型
hash是最接近关系数据库结构的数据类型,可以将数据库一条记录或程序中一个对象转换成hashmap存放在redis中。


三、各种数据类型所对应的应用场景
1.String类型的应用场景
String是最常用的一种数据类型,普通的key/value存储.

2.list类型的应用场景
比较适用于列表式存储且顺序相对比较固定,例如:省份、城市列表品牌、厂商、车系、车型等列表拆车坊专题列表…

3.set类型的应用场景
Set对外提供的功能与list类似,当需要存储一个列表数据,又不希望出现重复数据时,可选用set

4.zset(sorted set)类型的应用场景
zset的使用场景与set类似,区别是set不是自动有序的,而zset可以通过用户额外提供一个优先级(score)的参数来为成员排序,并且是插入有序的,即自动排序.当你需要一个有序的并且不重复的集合列表,那么可以选择zset数据结构。例如:根据PV排序的热门车系车型列表根据时间排序的新闻列表

5.hash类型的应用场景
类似于表记录的存储
页面视图所需数据的存储


四、Redis数据类型对应的常用命令行:
Jedis操作命令:

1.对value操作的命令
1
exists(key)  确认一个key是否存在
2
del(key)  删除一个key
3
type(key)  返回值的类型
4
keys(pattern)  返回满足给定pattern的所有key
5
randomkey:  随机返回key空间的一个key
6
rename(oldname, newname)  将key由oldname重命名为newname,若newname存在则删除newname表示的key
7
dbsize:  返回当前数据库中key的数目
8
expire:  设定一个key的活动时间(s)
9
ttl:  获得一个key的活动时间
10
select(index)  按索引查询
11
move(key, dbindex)  将当前数据库中的key转移到有dbindex索引的数据库
12
flushdb:  删除当前选择数据库中的所有key
13
flushall:  删除所有数据库中的所有key

2.对String操作的命令
1
set(key, value)  给数据库中名称为key的string赋予值value
2
get(key)  返回数据库中名称为key的string的value
3
getset(key, value)  给名称为key的string赋予上一次的value
4
mget(key1, key2,, key N)  返回库中多个string(它们的名称为key1,key2…)的value    s
5
setnx(key, value)  如果不存在名称为key的string,则向库中添加string,名称为key,值为value
6
setex(key, time, value)  向库中添加string(名称为key,值为value)同时,设定过期时间time
7
mset(key1, value1, key2, value2,…key N, value N)  同时给多个string赋值,名称为key i的string赋值value i
8
msetnx(key1, value1, key2, value2,…key N, value N)  如果所有名称为key i的string都不存在,则向库中添加string,名称          key i赋值为value i
9
incr(key)  名称为key的string增1操作
10
incrby(key, integer)  名称为key的string增加integer
11
decr(key)  名称为key的string减1操作
12
decrby(key, integer)  名称为key的string减少integer
13
append(key, value)  名称为key的string的值附加value
14
substr(key, start, end)  返回名称为key的string的value的子串

3.对List操作的命令
1
rpush(key, value)  在名称为key的list尾添加一个值为value的元素  
2
lpush(key, value)  在名称为key的list头添加一个值为value的 元素
3
llen(key)  返回名称为key的list的长度
4
lrange(key, start, end)  返回名称为key的list中start至end之间的元素(下标从0开始,下同)
5
ltrim(key, start, end)  截取名称为key的list,保留start至end之间的元素
6
lindex(key, index)  返回名称为key的list中index位置的元素
7
lset(key, index, value)  给名称为key的list中index位置的元素赋值为value
8
lrem(key, count, value)  删除count个名称为key的list中值为value的元素。count为0,删除所有值为value的元素,count>0      从头至尾删除count个值为value的元素,count<0从尾到头删除|count|个值为value的元素。
9
lpop(key)  返回并删除名称为key的list中的首元素
10
rpop(key)  返回并删除名称为key的list中的尾元素
11
blpop(key1, key2, key N, timeout)  lpop 命令的block版本。即当timeout为0时,若遇到名称为key i的list不存在或该list为空,则命令结束。如果 timeout>0,则遇到上述情况时,等待timeout秒,如果问题没有解决,则对key i+1开始的list执行pop操作。
12
brpop(key1, key2, key N, timeout)  rpop的block版本。参考上一命令。
13
rpoplpush(srckey, dstkey)  返回并删除名称为srckey的list的尾元素,并将该元素添加到名称为dstkey的list的头部

4.对Set操作的命令
1
sadd(key, member)  向名称为key的set中添加元素member
2
srem(key, member)   删除名称为key的set中的元素member
3
spop(key)   随机返回并删除名称为key的set中一个元素  
4
smove(srckey, dstkey, member)   将member元素从名称为srckey的集合移到名称为dstkey的集合
5
scard(key)   返回名称为key的set的基数        
6
sismember(key, member)   测试member是否是名称为key的set的元素
7
sinter(key1, key2,…key N)   求交集
8
sinterstore(dstkey, key1, key2,…key N)   求交集并将交集保存到dstkey的集合
9
sunion(key1, key2,…key N)   求并集
10
sunionstore(dstkey, key1, key2,…key N)   求并集并将并集保存到dstkey的集合
11
sdiff(key1, key2,…key N)   求差集
12
sdiffstore(dstkey, key1, key2,…key N)   求差集并将差集保存到dstkey的集合
13
smembers(key)   返回名称为key的set的所有元素
14
srandmember(key)   随机返回名称为key的set的一个元素

5.对zset(sorted set)操作的命令
1
zadd(key, score, member)  向名称为key的zset中添加元素member,score用于排序。如果该元素已经存在,则根据score更新该元素的顺序。
2
zrem(key, member)   删除名称为key的zset中的元素member
3
zincrby(key, increment, member)   如果在名称为key的zset中已经存在元素member,则该元素的score增加increment;否则向集合中添加该元素,其score的值为increment
4
zrank(key, member)   返回名称为key的zset(元素已按score从小到大排序)中member元素的rank(即index,从0开始),若没有member元素,返回“nil”
5
zrevrank(key, member)   返回名称为key的zset(元素已按score从大到小排序)中member元素的rank(即index,从0开始),若没有member元素,返回“nil”
6
zrange(key, start, end)  返回名称为key的zset(元素已按score从小到大排序)中的index从start到end的所有元素
7
zrevrange(key, start, end)  返回名称为key的zset(元素已按score从大到小排序)中的index从start到end的所有元素
8
zrangebyscore(key, min, max)  返回名称为key的zset中score >= min且score <= max的所有元素
9
zcard(key)  返回名称为key的zset的基数
10
zscore(key, element)  返回名称为key的zset中元素element的score
11
zremrangebyrank(key, min, max)  删除名称为key的zset中rank >= min且rank <= max的所有元素
12
zremrangebyscore(key, min, max)   删除名称为key的zset中score >= min且score <= max的所有元素
13
zunionstore / zinterstore(dstkeyN, key1,,keyN, WEIGHTS w1,…wN, AGGREGATE SUM|MIN|MAX)  对N个zset求并集和交集,并将最后的集合保存在dstkeyN中。对于集合中每一个元素的score,在进行AGGREGATE运算前,都要乘以对于的WEIGHT参数。如果没有提供WEIGHT,默认为1。默认的AGGREGATE是SUM,即结果集合中元素的score是所有集合对应元素进行 SUM运算的值,而MIN和MAX是指,结果集合中元素的score是所有集合对应元素中最小值和最大值。

6.对Hash操作的命令
1
hset(key, field, value)  向名称为key的hash中添加元素field<>value
2
hget(key, field)  返回名称为key的hash中field对应的value
3
hmget(key, field1, ,field N)  返回名称为key的hash中field i对应的value
4
hmset(key, field1, value1,,field N, value N)  向名称为key的hash中添加元素field i<>value i
5
hincrby(key, field, integer)  将名称为key的hash中field的value增加integer
6
hexists(key, field)  名称为key的hash中是否存在键为field的域
7
hdel(key, field)  删除名称为key的hash中键为field的域
8
hlen(key)  返回名称为key的hash中元素个数
9
hkeys(key)  返回名称为key的hash中所有键
10
hvals(key)  返回名称为key的hash中所有键对应的value
11
hgetall(key)  返回名称为key的hash中所有的键(field)及其对应的value




原创粉丝点击