过程

redis基础学习(一)之数据类型及其常用命令

2021-09-04  本文已影响0人  凯瑟鸭

最近因为一些原因用到Redis不得不学一点,就想着记录一下学习的印记。若有不对的地方还望指出为谢。

Redis (REmote DIctionary Server) 是用 C 语言开发的一个开源的高性能键值对(key-value)的非关系数据库,可以将存储在内存的键值对持久化到硬盘,可使用复制特性来扩展读性能。

Redis提供了五种不同数据结构类型与键(key)的映射,分别是Strng(字符串)、hash(散列)、list(列表)、set(集合)、zset(有序集合)。如下:

相应的命令:

Key的基本操作:

删除指定key   del key

获取key是否存在  exists key

获取key的类型    type key

改名rename key newkey  renamenx key newkey

查询key   keys pattern     pattern匹配规则:*匹配任意数量的任意符号 ?配合一个任意符号[] 匹配一个指定符号

String类型存储的数据:单个数据,最简单的数据存储类型,也是最常用的数据存储类型,一般做一些复杂的计数功能的缓存。

添加/修改数据  set key value        添加/修改多个数据  mset key1 value1 key2 value2 …

获取数据   get key                  获取多个数据 mget key1 key2 …

删除数据  del key

判定性添加数据  setnx key value

获取数据字符个数(字符串长度) strlen key

表示运行结果(integer) 0 → false 失败、(integer) 1 → true 成功如下图判断性加入name zhangsan 时因为前面有了故返回(integer) 0 表示已经存在

hash类型:底层使用哈希表结构实现数据存储

如field数量较少,存储结构为类数组结构否则存储结构使用HashMap结构

添加/修改数据hset key field value (hmset key field1 value1 field2 value2 …  多个时)

获取数据hget key field  hgetall key(hmget key field1 field2 …)

删除数据hdel key field1 [field2]

获取哈希表中字段的数量hlen key

获取哈希表中是否存在指定的字段hexists key field

list类型:保存多个数据,底层使用双向链表存储结构实现,允许用户从左右(left right)两端推入或弹出数据

rpush key value [value...] 将一个或者多个值推入列表的右端

lpush key value [value...] 将一个或者多个值推入列表的左端

Rpop key 移除并返回列表最右端的元素

Lpop key 移除并返回列表最左端的元素

Lrange  key  start end 返回指定范围内的所以元素

Lindex key offset 返回偏移量为offset的元素

set类型:以无序的的方式来存储多个各不相同的元素,与hash存储结构完全相同,但是无法启用hash中存储值的空间。

Sadd  key  item  [item.....]    将元素加入到集合中并返回被添加元素当中原本并不存在于集合里面的元素数量

Smembers  key 返回集合中所以的元素

Srem  key  item  [item.....]  移除元素返回移除数量

Sismember  key item  判断集合是否包含item数据

Scard  key  获取集合数据总量

Srandmember key  [count]   随机获取集合中指定数量的数据

Spop  key  [count] 随机移除集合中的一个元素或者指定数量并返回移除的元素

Smove  source-key  dest-key item  若是source-key包含item元素就从中移除item并加入到集合dest-key中,成功返回1否则返回0

求两个集合的交、并、差集

sdiff  key  [key ...]   返回存在于第一个集合但不存在与其他集合中的元素(数学上的差集运算)

Sinter  key   [key ... ]  返回那些同时存在于所有集合中的元素(数学上的交集运算)

Sunion  key  [key...]   返回那些至少存在于一个集合中的元素(数学上的并集计算)

求两个集合的交、并、差集并存储到指定集合中

sdiffstore dest-key  key  [key ...] 

sinterstore dest-key  key  [key ...]

sunionstore dest-key key  [key ...]

有序集合:存储结构和集合一样但是集合是无序的,有序集合存储着成员与分值之间的映射,并且提供了分值处理命令,以及根据分值大小有序地获取或扫描成员和分值的命令。

zadd key  score member [score member ...]  将带有给定分值的成员添加到有序集合里面

zrem key member [member ...]   从有序集合里面移除给定的成员,并返回被移除成员的数量

zcard key   获取集合数据总量

zrange key start stop   返回有序集合中排名介于start和stop之间的成员

希望路过的大佬不要嫌弃,若有不对之处还希望指正为谢!@~@

上一篇 下一篇

猜你喜欢

热点阅读