环境配置
拷贝Redis-x64-3.2.100到本地一个目录下,解压
然后设置环境变量PATH到该目录
Redis-server.exe:Redis服务端
Redis-cli.exe:Redis客户端
启动两个命令行,一个跑服务端,一个跑客户端
启动服务端:
redis-server.exe redis.windows.conf
启动客户端
redis-cli.exe
进入Redis的客户端命令行
测试命令:ping。如果响应PONG则表示redis已经成功运行了。
>>>ping
PONG
注意:Redis的端口号是6379,MySQL的端口号则为3306
命令语句
先记录一下Redis数据类型:
Redis中永远是key-value的数据。其中,键永远是字符串,值可以是如下的内容:
- string(字符串)(常用)
- hash(哈希)(加密运算)
- list(列表)
- set(无序集合)
- zset(有序集合)
string(字符串)
--set 设置键对应的值
SET key calue --get 获取间对应的值
GET key --如果get一个不存在的键则返回nil --mget 一次获取多个值
mget key[key ...] --append 往现有的字符串后面追加值
append key value --strlen 查看字符串长度
strlen key
Key(键操作)
-- keys 查找键
keys pattern --查找的键不存在。显示 empty list or set --查找所有的键
keys * --exist 判断键是否存在。存在返回1,否则返回0
exist key[key...] --type 查看类型
type key --del 删除键
del key [key...] --expire 设置键的过期时间(s)
expire key seconds
hash(哈希)
--哈希可以理解为python中字典
--对应到python里就是 key = {'field':value,'field1':value1} --hset 添加元素
hset key field value --hget 获取元素
hget key field value --hkeys 返回所有属性
hkeys key --hvals 返回所有值
hvals key --hgetall 返回所有属性和值
hgetall key --返回包含属性和值的长度
hlen key
list(列表)
--列表可以从左或者从右插入元素
--lpush 从列表左边插入
lpush key value[value...] -- rpush 从列表右边插入
rpush key value[value...] --lrange 查看列表元素
lrange key satart stop
lrange myliest 0 -1 --linsert 左边开始从某元素旁边插入(没有 rinsert)
linsert key BERORE/AFTER pivot value
linsert kumata before masiwei --pop 出来 lpop rpop
lpop key
rpop key
set(集合)
--集合与列表、元祖最大区别为没有index
--sadd 往集合中添加元素(会随机添加进去)
sadd key member [member...] --smembers 获取所有元素
smembers key --scard 获取元素个数
scard key --sinter 求多个集合交集
sinter key [key...] --sunion 求多个集合并集
sunion key [key...] --sdiff 求多个集合差集
sdiff key [key...] --sismember 判断元素是否在集合中
sismember key member
sismember myset kumata
sorted set (有序集合)
--有序集合的特点:每个元素都有两个属性
--score得分:按照得分值来排序
--member成员:集合中的值 -- zadd 添加元素
zadd key [NX|XX] [CH] [INCR] score member [score member ...]
zadd myset 1 kumata 2 masiwei 4 melo 3 dz --zrange 查看成员
zrange key start stop [WITHSCORES]
zrange myset 0 -1 --返回集合中分值范围内的元素
zcount key min max
Redis中的订阅和发布
可以启动两个客户端,在一个客户端发布,另一个客户端订阅
--客户端A:使用subscribe命令进行订阅
subscribe channel [channel ...]
程序停下来,并没有退出,在等待发布
--客户端B:使用publish进行发布
publish channel message
然后A多了东西