(一)为什么要用Nosql
如果你是计算机本科学生 ,那么一定使用过关系型数据库mysql。在请求量小的情况下,使用mysql不会有任何问题,但是一旦同时有成千上万个请求同时来访问系统时,就会出现卡顿甚至系统崩溃的情况。最典型的例子就是早期的12306购票网站,一旦到了购票高峰期,12306肯定崩溃。造成这个原因的罪魁祸首就是关系型数据库。
为了解决这两个问题,非关系型数据库出现了,非关系型数据库有两个特点:
(二)redis介绍
Redis是用C语言开发的一个开源的高性能键值对(key-value)数据库,他有如下几个特征:
4.多数据类型支持:字符串类型(string)、列表类型(list)、散列类型(hash)、集合类型(set)、有序集合类型(sorted_set)
Redis的应用场景也非常广泛,如热点新闻、购票抢票、即时信息查询、时效性信息控制、消息队列、分布式锁等等。
(三)redis数据类型操作
介绍完nosql和redis后就开始正式操作redis了,确保你此时已经下载安装redis服务,并且已经打开服务。
3.1 string类型
set key value
get key
del key
添加修改多个数据
mset key1 value1 key2 value2 ...
mget key1 key2...
strlen key
append key value
多操作指令看上去似乎是对单操作指令的简单相加,但其实不然。一条指令执行有三个地方需要耗时:发送指令、处理指令、返回结果。当使用多操作指令的时候,发送和返回都只执行一次,相比较多次只从单操作指令减少了大笔时间。
-
incr key
-
incrby key increment
-
incrbtfloat key increment
-
decr key
-
decrby key increment
-
setex key seconds value
-
psetex key milliseconds value
以上就是string类型的语法操作,对于key值的命名规范也有指定的约定,比如对于一个微博大V的粉丝数,微博数,关注数可以用下面的方法命名:
-
user:id:123456:fans
-
user:id:123456:blogs
-
user:id:123456:focus
3.2hash类型
hash类型主要用于在一个存储空间内保存多个键值对信息。比如上面微博的三项基本数据,如果按照上面的方式就需要三条数据,这里就可以中hash存储。
hset key field value
-
hget key field
-
hgetall key
hdel key field
hmset key field1 value1 field2 value2...
hmget key field1 field2
hlen key
hexists key field
-
hkeys key
-
hvals key
-
hincrby key field increment
-
hincrbyfloat key field increment
hash类型的操作至此也结束了,需要注意的是,hash类型下的value只能存储字符串,不允许存储其他数据类型,不存在嵌套现象。每个hash可以存储2^32-1个键值对。
3.3 list类型
list类型数据用于存储多个数据,并对数据进入存储空间的顺序进行区分。list类型的数据可以保存多个数据,底层使用双向链表存储结构实现。
既然是双向链表的方式实现,那么就可以从左右两边添加和修改数据,下面是具体操作
-
lpush key value1 value2...
-
rpush key value1 value2...
-
lrange key start stop (stop=-1时表示最后一个元素)
-
lindex key index
-
llen key
-
lpop key
-
rpop key
-
blpop key1 key2 timeout
-
brpop key1 key2 timeout
这条命令的意思是当列表中没有元素时,会等待timeout指定的时间,期间一旦有数据加入到List列表中,就会显示出来,否则时间到了后就显示为空。
lrem key count value
3.4 set类型
set类型与hash存储结构完全相同,不同点在于,set仅存储键,不存储值,并且值不允许为空。
添加数据
sadd key member1 member2...
smembers key
srem key member1 member2...
scard key
sismember key member
srandmember key [count]
spop key
-
sinter key1 key2 ..
-
sunion key1 key2 ..
-
sdiff key1 key2 ..
-
sinterstore destination key1 key2 ..
-
sunionstore destination key1 key2 ..
-
sdiffstore destination key1 key2 ..
smove source destination member
set的操作到这里就结束了,要注意set类型的数据不允许重复,且set虽然与hash存储结构相同,但是无法启用hash中的存储空间
3.5 sorted_set类型
sorted_set在set的基础上添加了可排序字段,使得存储可按可排序字段来排序,这个可排序字段称为score。
zadd key score1 member1 score2 member2 ...
-
zrange key start stop [withscores]
-
zrevrange key start stop [withscores]
zrem key member1 member2...
-
zrangebyscore key min max [withscores] [limit]
-
zrevrangebyscore key max min [withscores]
-
zremrangebyrank key start stop
-
zremrangebyscore key min max
-
zcard key
-
zcount key min max
-
zinterstore destination numkeys key1 key2...(求交集,默认求出score的和,可以修改为最大值最小值等等)
-
zunionstore destination numkeys key1 key2...