Redis数据类型

一、Redis数据类型:

这里所涉及到的数据类型一般是指value的数据类型,key的类型都是字符串

(1).字符串类型(String):

string是redis最基本的类型,一个key对应一个value;string类型是二进制安全的,意思是redis的string可以包含任何数据,比如jpg图片或者序列化的对象;string类型是Redis最基本的数据类型,一个redis中字符串value最多可以是512M;

(2).列表类型(List):

Redis列表是简单的字符串列表,按照插入顺序排序可以添加一个元素到列表的头部(左边)或者尾部(右边);它的底层实际是个双端链表,最多可以包含 2^32-1 个元素

(3).哈希类型(Hash)

Redis hash是一个string类型的field(字段)和value(值)的映射表,hash特别适合用于存储对象。Redis中每个hash可以存储2^32-1键值对

(4).集合类型(Set)

Redis的Set是String类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据,集合对象的编码可以是 ntset或者hashtable;Redis中Set集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1);集合中最大的成员数为 2^32-1

(5).有序集合(ZSet)

zset(sorted set:有序集合),Redis zset和set一样也是string类型元素的集合,且不允许重复的成员。不同的是每个元素都会关联一个double类型的分数,redis正是通过分数来为集合中的成员进行从小到大的排序;zset的成员是唯一的,但分数(score)却可以重复;zset集合是通过哈希表实现的,所以添加,删除,査找的复杂度都是 (1);集合中最大的成员数为 2^32-1;

(6).地理空间类型(GEO)

Redis GEO主要用于存储地理位置信息,并对存储的信息进行操作,包括添加地理位置的坐标、获取地理位置的坐标、计算两个位置之间的距离以及、根据用户给定的经纬度坐标来获取指定范围内的地理位置集合

(7).基数统计(HyperLog Log):

HyperLog Log是用来做基数统计的算法,HyperLogLog的优点是在输入元素的数量或者体积非常非常大时,计算基数所需的空间总是固定且是很小的;在Redis里面每个HyperLogLog键只需要花费 12 KB内存,就可以计算接近 2^64个不同元素的基数。这和计算基数时元素越多耗费内存就越多的集合形成鲜明对比;但是因为HyperLogLog只会根据输入元素来计算基数,而不会储存输入元素本身,所以HyperLogLog不能像集合那样返回输入的各个元素。

(8).位图(BitMap):

由0和1状态表现的二进制位的bit数组

(9).位域(BitField):

通过bitield命令可以一次性操作多个比特位域(指的是连续的多个比特位),它会执行一系列操作并返回一个响应数组,这个数组中的元素对应参数列表中的相应操作的执行结果。说白了就是通过bitfield命令我们可以一次性对多个比特位域进行操作。

(10).流(Stream):

Redis stream主要用于消息队列(MQ,Message Queue),Redis 本身是有一个Redis发布订阅(pub/sub)来实现消息队列的功能,但它有个缺点就是消息无法持久化,如果出现网络断开、Redis 宕机等,消息就会被丢弃。简单来说发布订阅(pub/sub)可以分发消息,但无法记录历史消息。而Redis stream提供了消息的持久化和主备复制功能,可以让任何客户端访问任何时刻的数据,并目能记住每一个客户端的访问位置,还能保证消息不丢失

二、Redis常用key操作命令

(1).DEL key:用于在key存在时删除key

(2).DUMP key:序列化指定key,并返回被序列化的值

(3).EXISTS key:检查指定的key是否存在

(4).EXPIRE key seconds:为给定的key设置过期时间

(5).EXPIREAT key seconds:为给定的key设置过期事件,接受的时间参数时UNIX时间戳

(6).PREPIRE key milliseconds:设置key的过期时间以毫秒计

(7). PEXPIREAT key milliseconds-timestamp:设置key过期时间的时间戳(unix timestamp),以毫秒计

(8).KEYS pattern:查找所有符合给定模式的key,keys *返回当前数据库中全部的key

(9).MOVE key db:将当前数据库的key移动到给定的数据库db中,db的取值范围为0~15

(10).PERSIST key:移除key的过期时间,key将持久保持

(11).PTTL key:以毫秒为单位返回key的剩余过期时间

(12).TTL key:以秒为单位,返回给定key的剩余生存时间

(13).RANDOMKEY:从当前数据库中随机返回一个key

(14).RENAME key newkey:修改key的名称

(15).RENAMENX key newkey:仅当newkey不存在时将key改名为newkey

三、Redis十大类型常见操作:

Redis中命令不区分大小写,而key是区分大小写的;帮助命令为help @类型

1.Redis字符串(String):单值单value

(1).set key value [NX|XX] [GET] [EX seconds|PX milisecondslEXAT unix-time-seconds|PXAT unix-time-miliseconds|KEEPTTL]:

a.EX seconds:以秒为单位设置过期时间

b.PX milliseconds:以毫秒为单位设置过期时间

c.EXAT timestamp:设置以秒为单位的UNIX时间戳所对应的时间为过期时间

d.PXAT milliseconds-timestamp:设置以毫秒为单位的UNIX时间戳所对应的时间为过期时间

e.NX:键不存在的时候设置键值

f.XX:键存在的时候设置键值

g.KEEPTTL:保留设置前指定键的生存时间

h.GET:返回指定键原本的值,若键不存在时返回nil

(2).同时设置/获取多个键值:

MSET key1 value1[key2 value2 .....]:设置key1的值为value1,key2的值为value2,以此类推

MGET key1[key2 ...]:同时获取key1、key2等多个key的值

MSETNX key1 value1[key2 value2 .....]:只有所有的key都不存在时才会执行成功,不会只执行命令中的一部分内容(要么都成功,要么全部失败)

(3).获取指定区间范围内的值:类似于Java中的substring的操作

getrange key a,b:获取key对应值区间[a,b)范围内的数据

setrange key offset v1:将key1对应值偏移量offset开始处的内容替换为v1,被替换内容的长度和v1相同;

(4).数值增减:类似于Java中的++、--,一定是数值才能够增减

INCR key:递增数字,每次递增1

INCR BY key increment:增加指定的整数increment

DECR key:递减数值,每次递减1

DECR BY key decrement:减少指定的整数decrement

(5).获取字符串长度和内容追加

STRLEN key:获取key对应value的字符串长度

APPEND key value:将key对应的值后增加字符串value

(6).分布式锁:

SETEX key seconds value:设置过期时间(原子操作)

SETNX key value:当键不存在时才会设置成功

(7).getset key value:先获取key的值再设置key的值为value

2.Redis列表(list):单key多value

底层是一个双端链表的结构,主要功能是push和pop,一般用在栈、队列、消息队列等场景;该链表的left和right都可以插入和添加;如果键不存在,则创建新的链表,如果键已经存在,则新增内容;如果值全部移除,则对应的键也就消失了

(1).lpush/rpush/lrange:

LPUSH list value1,value2,...,valueN:将value1,value2,...,valueN从list的左端依次插入

RPUSH list value1,value2,...,valueN:将value1,value2,...,valueN从list的右端依次插入

LRANGE list from  to:从左往右依次遍历list中序列为from到to之间的内容

(2).lpop/rpop:

LPOP list:从list的左侧弹出一个元素,元素从列表中移除

RPOP list:从list的右侧弹出一个元素,元素从列表中移除

(3).LINDEX:按照索引下标获得元素(从上到下)

LINDEX list index:获取list中从左往右数第index的元素

(4).LLEN list:获取list的长度,即获取list中元素的个数

(5).LREM key 数字N 给定值value:删除列表key中N个值等于value的元素,从左往右删除

(6).LTRIM key begin end:截取列表key指定范围(begin,end)值后赋值给列表key,从左往右截取

类似sublist

(7).RPOPLPUSH 源列表list1 目的列表list2:移除列表的最后一个元素,并将元素添加到另外一个列表的开始位置并返回list2

(8).LSET key index value:设置列表key的位置index处的元素为value

(9).LINSERT key BEFORE/AFTER value1 value2:将新的值value2插入到列表key的已有值value的前面或者后面

Redis支持多种数据类型,包括string、hash、list、set和sorted set等。其中,string是最基本、最简单的数据类型,用于存储字符串。 Hash是用于存储键值对的数据结构,其中的value只能存储字符串,不允许存储其他数据类型,也不存在嵌套现象。每个hash可以存储232 - 1个键值对,并可以灵活添加或删除对象属性。但需要注意的是,hash类型并不适合存储大量对象,也不应该将hash作为对象列表使用,因为遍历整体数据的效率可能会较低。 除了string和hash类型,Redis还支持list、set和sorted set等数据类型。List是一个有序的字符串列表,可以进行插入、删除和查找等操作。Set是一个无序的字符串集合,可以进行元素的添加、删除和查找操作,并且不允许重复元素的存在。Sorted Set是一个有序的字符串集合,每个元素都有一个对应的score,可以根据score进行排序和范围查找。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Redis 数据类型](https://blog.csdn.net/weixin_52851967/article/details/122670564)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值