redis常用命令

目录

一、认识redis

1、Redis数据结构介绍

2、Redis常用命令

二、Redis基本数据类型

1、String类型

2、Hash类型

3、List类型

4、Set类型

5、SortedSet(zset)类型


关系型数据库(SQL)与非关系型数据库(NoSQL)的区别

SQLNoSQL
数据结构结构化(Structured)非结构化
数据关联关联的(Relational)无关联的
查询方式SQL查询非SQL
事务特性ACID(事务四大特性)BASE
存储方式磁盘内存
扩展性垂直水平
使用场景

1)数据结构固定

2)相关业务对数据安全性、
—致性要求较高

1)数据结构不固定

2)对一致性、安全性要求不高

3)对性能要求

一、认识redis

Redis诞生于2009年全称是Remote Dictionary Server,远程词典服务器,是一个基于内存的键值

型NoSQL数据库。

特征:

1、键值( key-value)型,value支持多种不同数据结构,功能丰富

2、单线程,每个命令具备原子性

3、低延迟,速度快(基于内存、IO多路复用、良好的编码)

4、支持数据持久化

5、支持主从集群、分片集群

6、支持多语言客户端

1、Redis数据结构介绍

Redis是一个key-value的数据库,key一般是String类型,不过value的类型多种多样:

前5种是基本类型,后面是特殊类型

stringhello world
Hash{name: "Jack",age: 21}

List

[A ->B ->C ->C]

Set

{A,B,C}
SortedSet(zset){A: 1,B:2,C: 3}
GEO{A:(120.3,30.5)}
BitMap0110110101110101011
HyperLog0110110101110101011

2、Redis常用命令

命令说明
keys *查看当前库所有 key (匹配:keys *1)
exists key判断某个 key 是否存在
type key查看你的 key 是什么类型
del key删除指定的 key 数据
unlink key根据 value 选择⾮阻塞删除 仅将keys从keyspace元数据中删除,真正的删除会在后续异步操作。
expire key 1010秒钟:为给定的key设置过期时间
ttl key查看还有多少秒过期,-1 表示永不过期,-2 表示已过期
select命令切换数据库
dbsize查看当前数据库的 key 的数量
flushdb清空当前库
flushall通杀全部库

可以通过help命令查看具体语法,例如:


 

二、Redis基本数据类型

1、String类型

String类型,也就是字符串类型,是Redis中最简单的存储类型。其value是字符串,不过根据字符

串的格式不同,又可以分为3类:

        string:普通字符串

        int:整数类型,可以做自增、自减操作

        float:浮点类型,可以做自增、自减操作

不管是哪种格式,底层都是字节数组形式存储,只不过是编码方式不同。字符串类型的最大空间不

能超过512M

String常见命令

SET添加或者修改已经存在的一个string类型的键值对
GET根据key获取String类型的value
MSET批量添加多个String类型的键值对
MGET根据多个key获取多个String类型的value
INCR让一个整型的key自增1
INCRBY让一个整型的key自增并指定步长,例如: incrby num 2让num值自增2
INCRBYFLOAT让一个浮点类型的数字自增并指定步长
SETNX添加一个String类型的键值对,前提是这个key不存在,否则不执行
SETEX添加一个String类型的键值对,并且指定有效期
append将给定的 追加到原值的末尾
strlen获得值的⻓度
decr将 key 中储存的数字值减 1 只能对数字值操作,如果为空,新增值为 -1

key的层级结构

问:Redis没有类似MySQL中的Table的概念,我们该如何区分不同类型的key呢?

例如,需要存储用户、商品信息到redis,有一个用户id是1,有一个商品id恰好也是1

Redis的key允许有多个单词形成层级结构,多个单词之间用“ : ”隔开,例如:

项目名:业务名:类型:id               这个格式并非固定,也可以根据自己的需求来删除或添加词条。

例如我们的项目名称叫 demo,有user和product两种不同类型的数据,我们可以这样定义key:

user相关的key: demo:user: 1

product相关的key: demo:product:1

如果Value是一个Java对象,例如一个User对象,则可以将对象序列化为JSON字符串后存储:

keyvalue
demo:user:1'{"id":1, "name":"Jack", "age": 21}'
demo:product:1'{"id":1, "name":"小米11", "price": 4999}'

192.168.138.129:6379> set demo:user:1 {"id":1, "name":"Jack", "age": 21}
Invalid argument(s)
192.168.138.129:6379> set demo:user:1 '{"id":1, "name":"Jack", "age": 21}'
OK
192.168.138.129:6379> set demo:product:1 '{"id":1, "name":"小米11", "price": 4999}'
OK
192.168.138.129:6379> set demo:user:1 '{"id":2, "name":"Rose", "age": 18}'
OK
192.168.138.129:6379> set demo:user:2 '{"id":2, "name":"Rose", "age": 18}'
OK

 

2、Hash类型

Redis hash 是⼀个键值对集合。 Redis hash 是⼀个 string 类型的 field 和 value 的映射表,hash

特别适合⽤于存储对象。 类似 Java ⾥⾯的 HashMap

命令说明
HSET key field value添加或者修改hash类型key的field的值
HGET key field获取一个hash类型key的field的值
HMSET批量添加多个hash类型key的field的值
HMGET批量获取多个hash类型key的field的值
HGETALL获取一个hash类型的key中的所有的field和value
HKEYS获取一个hash类型的key中的所有的field
HVALS获取一个hash类型的key中的所有的value
HINCRBY让一个hash类型key的字段值自增并指定步长
HSETNX添加一个hash类型的key的field值,前提是这个field不存在,否则不执行
192.168.138.129:6379> hset demo:user:3 name lisi
(integer) 1
192.168.138.129:6379> hset demo:user:3 age 20
(integer) 1
192.168.138.129:6379> hget demo:user:3 name
"lisi"
192.168.138.129:6379> hget demo:user:3 age
"20"
192.168.138.129:6379> hmset demo:user:4 name wangwu age 20
OK
192.168.138.129:6379> hmget demo:user:4 name age
1) "wangwu"
2) "20"
192.168.138.129:6379> hgetall demo:user:4
1) "name"
2) "wangwu"
3) "age"
4) "20"
192.168.138.129:6379> hkeys demo:user:4
1) "name"
2) "age"
192.168.138.129:6379> hvals demo:user:4
1) "wangwu"
2) "20"
192.168.138.129:6379> hincrby demo:user:4 age 2
(integer) 22
192.168.138.129:6379> hincrby demo:user:4 age -2
(integer) 20
192.168.138.129:6379> 

 

3、List类型

Redis中的List类型与Java中的LinkedList类似,可以看做是--个双向链表结构。既可以支持正向检

索和也可以支持反向检索。

特征也与LinkedList类似:有序、元素可以重复、插入和删除快、查询速度一般

List常见命令:

命令说明
LPUSH key element ...向列表左侧插入一个或多个元素
LPOP key移除并返回列表左侧的第一个元素,没有则返回nil
RPUSH key element ...向列表右侧插入一个或多个元素
RPOP key移除并返回列表右侧的第一个元素
LRANGE key star end返回一段角标范围内的所有元素
BLPOP和BRPOP与LPOP和RPOP类似,只不过在没有元素时等待指定时间,而不是直接返回nil
 
leange<key><start><stop>按照索引下标获得元素(从左到右)
lindex<key><index>按照索引下标获得元素(从左到右)
llen<key>获得列表长度
lrem<key><n><value>从左边删除n个value(从左到右)
lset<key><index><value>将列表key下标为index的值替换成value

如何利用List结构模拟一个栈?

        入口和出口在同一边

如何利用List结构模拟一个队列?

        入口和出口在不同边

如何利用List结构模拟一个阻塞队列

        入口和出口在不同边,出队时采用BLPOP或BRPOP

4、Set类型

Redis的Set结构与java中的HashSet类似,可以看做是一个value为null的HashMap。因为也是一个

hash表,因此具备与HashSet类似的特征:

无序、元素不可重复、查找快、支持交集、并集、差集等功能

常见Set命令

命令说明
smove <source><destination><value>把集合中一个值从一个集合移动到另一个集合
srandmember key n随机从该集合中取出n个值,不会删除
spop key随机从该集合中吐出一个值
sinter key1 key2返回两个集合的交集元素
SADD key member ...向set中添加一个或多个元素
SREM key member ...移除set中的指定元素
SCARD key返回set中元素的个数
SISMEMBER key member判断一个元素是否存在于set中
SMEMBERS获取set中的所有元素
SINTER key1 key2 ...求key1与key2的交集
SDIFF key1 key2 ...求key1与key2的差集
SUNION key1 key2 ..求key1和key2的并集

5、SortedSet(zset)类型

Redis的SortedSet是一个可排序的set集合,与Java中的TreeSet有些类似,但底层数据结构却差别

很大。SortedSet中的每一个元素都带有一个score属性,可以基于score属性对元素排序,底层的

实现是一个跳表(SkipList)加 hash表。

特点:可排序、元素不重复、查询速度快

因为SortedSet的可排序特性,经常被用来实现排行榜这样的功能。

常用命令:

命令说明
ZADD key score member添加一个或多个元素到sorted set,如果已经存在则更新其score值
zrevrangebyscore key max min按照score排序后,获取指定score范围内的元素,从⼤到⼩排列
ZREM key member删除sorted set中的一个指定元素
ZSCORE key member获取sorted set中的指定元素的score值
ZRANK key member获取sorted set中的指定元素的排名
ZCARD key获取sorted set中的元素个数
ZCOUNT key min max统计score值在给定范围内的所有元素的个数
ZINCRBY key increment member让sorted set中的指定元素自增,步长为指定的increment值:
ZRANGE key min max按照score排序后,获取指定排名范围内的元素
ZRANGEBYSCORE key min max按照score排序后,获取指定score范围内的元素(从⼩到⼤)
ZDIFF、ZINTER、ZUNION求差集、交集、并集

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值