使用redis前得先安装redis,具体安装步骤请参考 ,安装好后就可以使用咯。
redis的数据存储是key-value格式的,例如,要存储一个名字为zls的用户,用redis来写的话,就是:set name zls
value有5种数据类型:string、list、set、sort set 、hash。具体使用如下:
1.key的操作
命名:key的命名规则不同于一般语言,键盘上除了空格、换行外其他的大部分字符都可以使用。像“my key”和“mykey\n”这样包含空格和换行的key是不允许的。
用法如下图:
具体使用:
exists key 测试指定key是否存在,存在则返回1,否则为0
del key1 key2 删除指定的key
type key 返回指定key的value类型
keys pattern 返回匹配指定模式的所有key
例如:keys *g* 返回key名中包含g的 keys * 返回所有key
randomkey 返回从当前数据库中随机选择的一个key
rename oldkey newkey 改名字
expire key seconds 为key指定过期时间
ttl key 返回key的过期剩余秒数
dbsize 返回当前数据库中的key数量
select db-idex 选择数据库
例如:redis默认总共有16个数据库,都是没有名字的,只有索引下标。第一个数据库的索引是0,默认当前的数据库是第一个数据库。选择第4个则用 select 3。
move key db-index 移动指定的key到某个数据库
flushdb 删除当前数据库中所有key
flushall 删除所有数据库中的所有key
我事先设置了name的值为zls
切换数据库
2.String类型操作
string是redis最基本的类型。redis的string可以包含任何数据。包括jpg图片或者序列化的对象。单个value值最大上限是1G字节。 如果只用string类型,redis就可以被看作加上持久化特性的memcache。
用法如下图:
关于incr的用法:
incr(increament)对陌生或已有key(key的值必须为整型)进行累加1操作,实现网站计数器功能。
操作陌生变量:生成该key变量并取值为1,
操作已有的key变量:要求key的值必须为整型的。
具体操作如下图:
3.List链表类型操作
list类型其实就是一个双向链表。通过push,pop操作从链表的头部或者尾部添加删除元素。这使得list既可以用作栈,也可以用作队列。
list链表类型应用场合:获得最新的10个商品:select * from goods order by id desc limit 10; 该sql语句可以实现需求,但是数据多的时候,全部数据都要受到影响,对数据库的负载比较高。
如果使用list链表链表实现以上功能,就会极大节省各方面资源消耗,可以在list链表中保留最新的10个数据,旧的数据从链表中给去除。每次从链表中直接获取数据即可。
用法:
具体操作
(1)添加数据
(2)删除数据,可知把nokia删除了
或者用下面的lrem,这个用的比较少。
(3)截取数据,不在区间内的会被自动删除
(4)修改
4.set集合类型操作
redis的set是string类型的无序集合。set元素最大可以包含(2的32次方-1)个元素。
关于set集合类型除了基本的添加删除操作,其他有用的操作还包含集合的取并集(union),交集(intersection),差集(difference)。通过这些操作可以很容易的实现sns中的好友推荐功能。该类型应用场合:qq好友推荐、微博系统的关注关系使用.
例如微博系统关注关系:① 我去关注他人②我被别人关注③大家互相关注
举个例子:
有两个set集合类型的数据(tom和linken的好友信息):
tom关注别人(mary jack wang5 wang6) linken关注别人(yuehan luce wang5 wang6)
可知tom和linken有各自的好友,也有共同的两个好友,但是他们彼此不是好友。
set用法如下图:
具体操作。
(1)往set里添加元素。
(2)交集,并集,差集
差集,谁排前面就只能保留谁的。
5.Sort Set排序集合类型
和set一样sorted set也是string类型元素的集合,不同的是每个元素都会关联一个权。通过权值可以有序的获取集合中的元素。排序集合中的每个元素都包括两部分信息:值、权。三种类型区别如下:
set类型:集合类型、内部元素没有顺序,同一个集合没有重复元素
list链表类型:内部元素有彼此的先后顺序,同一个链表允许有重复元素
Sort set类型:排序集合类型,相比set类型有排序功能
Sort set类型适合场合:
获得热门帖子(回复量)信息:select *from message order by backnum
根据学生成绩排序获得信息等: select * from student order by 成绩 desc
(以上需求可以通过简单sql语句实现,但是sql语句比较耗费mysql数据库资源,不如使用redis的sort set更加科学)
Sort Set用法如下图:
案例:利用sortset实现获取成绩高的前5个学生信息(500万个学生)
先插入5条模拟记录。
两种方式排序
剔除分数最低的 zremrangebyrank student 0 0
6. hash数据类型
hash数据类型是redis模仿数据库把一条记录信息给存储起来。用得很少。
hash用法如下图:
具体使用