redis:五大类型用法

发布时间:2023年12月20日

Redis五大类型:字符串(String)、哈希/散列/字典(Hash)、列表(List)、集合(Set)、有序集合(sorted set)五种。

Controller:@Resource RedisTemplate<String, String> redisTemplate;
redisTemplate.opsForValue();//操作字符串
redisTemplate.boundValueOps("keyValue").set("value");//操作字符串

redisTemplate.opsForHash();//操作hash
redisTemplate.boundHashOps("keyHash").put("key","value");//操作hash

redisTemplate.opsForList();//操作list
redisTemplate.boundListOps("keyList").leftPush("value");//操作lis

redisTemplate.opsForSet();//操作set
redisTemplate.boundSetOps("keySet").add("values");//操作set

redisTemplate.opsForZSet();//操作有序set
redisTemplate.boundZSetOps("keyZSet").add("values",1.0);//操作有序set

String

编号命令描述说明
1SET key value此命令设置指定键的值。
2GET key获取指定键的值
3GETRANGE key start end获取存储在键上的字符串的子字符串
4GETSET key value设置键的字符串值并返回其旧值
5GETBIT key offset返回在键处存储的字符串值中偏移处的位值
6MGET key1 [key2..]获取所有给定键的值
7SETBIT key offset value存储在键上的字符串值中设置或清除偏移处的位
8SETEX key seconds value使用键和到期时间来设置值
9SETNX key value设置键的值,仅当键不存在时
10SETRANGE key offset value在指定偏移处开始的键处覆盖字符串的一部分
11STRLEN key获取存储在键中的值的长度
12MSET key value [key value …]为多个键分别设置它们的值
13MSETNX key value [key value …]为多个键分别设置它们的值,仅当键不存在时
14PSETEX key milliseconds value设置键的值和到期时间(以毫秒为单位)
15INCR key将键的整数值增加1
16INCRBY key increment将键的整数值按给定的数值增加
17INCRBYFLOAT key increment将键的浮点值按给定的数值增加
18DECR key将键的整数值减1
19DECRBY key decrement按给定数值减少键的整数值
20APPEND key value将指定值附加到键
//编号1:
redisTemplate.opsForValue().set(key,value)); 

//编号2:
redisTemplate.opsForValue().get(key)); 

//编号3:
redisTemplate.opsForValue().get(key, start, end);

//编号4:
redisTemplate.opsForValue().getAndSet(key, value);

//编号5:
redisTemplate.opsForValue().getBit(key, offset);//下方注释

//编号6:
redisTemplate.opsForValue().multiGet(keys);

//编号7:
redisTemplate.opsForValue().setBit(key, offset, value);//下方注释

//编号8、14:
redisTemplate.opsForValue().set(K key, V value, long timeout, TimeUnit unit);//TimeUnit是timeout的类型,如毫秒\秒\天等

//编号9:
redisTemplate.opsForValue().setIfAbsent(key, value);

//编号10:
redisTemplate.opsForValue().set(K key, V value, long offset);//博主此处未做java验证

//编号11:
redisTemplate.opsForValue().size(key));

//编号12:
redisTemplate.opsForValue().multiGet(Collection<K> keys);

//编号13:
redisTemplate.opsForValue().multiSetIfAbsent(Map<? extends K, ? extends V> m);

//编号15、16、17、18、19:
redisTemplate.opsForValue().increment(K key, long delta);
//或:
redisTemplate.opsForValue().increment(K key, double delta);


//编号20:
redisTemplate.opsForValue().append(key, value);//在key键对应值的右面追加值value

//删除方法
del key
redisTemplate.opsForValue().getOperations().delete(key);

Hash

Redis hash是一个string类型的field(字段) 和 value(值) 的映射表,hash特别适合用于存储对象。

Redis中每个hash可以存储
2 32 ? 1 2^{32} -1 232?1
键值对(40多亿)。

编号命令描述说明
1HDEL key field2 [field2]删除一个或多个哈希字段
2HEXISTS key field判断是否存在散列字段
3HGET key field获取存储在指定键的哈希字段的值
4HGETALL key获取存储在指定键的哈希中的所有字段和值
5HINCRBY key field increment将哈希字段的整数值按给定数字增加
6HINCRBYFLOAT key field increment将哈希字段的浮点值按给定数值增加
7HKEYS key获取哈希中的所有字段
8HLEN key获取散列中的字段数量
9HMGET key field1 [field2]获取所有给定哈希字段的值
10HMSET key field1 value1 [field2 value2 ]为多个哈希字段分别设置它们的值
11HSET key field value设置散列字段的字符串值
12HSETNX key field value仅当字段不存在时,才设置散列字段的值
13HVALS key获取哈希中的所有值
//编号1:
redisTemplate.opsForHash().delete(H key, Object... hashKeys);//...表示可以传入多个map的key,用,隔开。或用数组传值

//编号2:
redisTemplate.opsForHash().hasKey(key, hashKey);

//编号3:
redisTemplate.opsForHash().get(key, hashKey);

//编号4:
redisTemplate.opsForHash().entries(key);//返回map集合

//编号5、6:
redisTemplate.opsForHash().increment(H key, HK hashKey, long delta);
//或
redisTemplate.opsForHash().increment(H key, HK hashKey, double delta);

//编号7:
redisTemplate.opsForHash().keys(key);//返回map的key集合Set

//编号8:
redisTemplate.opsForHash().size(key);

//编号9:
redisTemplate.opsForHash().multiGet(H key, Collection<HK> hashKeys);

//编号10:
redisTemplate.opsForHash().putAll(H key, Map<? extends HK, ? extends HV> m);

//编号11:
redisTemplate.opsForHash().put(key, hashKey, value);

//编号12:
redisTemplate.opsForHash().putIfAbsent(key, hashKey, value);

//编号13:
redisTemplate.opsForHash().values(key);//返回map中的value集合List;

List

Redis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)

一个列表最多可以包含
2 32 ? 1 2^{32}-1 232?1
个元素 (4294967295, 每个列表超过40亿个元素)。

编号命令描述说明
1BLPOP key1 [key2 ] timeout删除并获取列表中的第一个元素,或阻塞,直到有一个元素可用
2BRPOP key1 [key2 ] timeout删除并获取列表中的最后一个元素,或阻塞,直到有一个元素可用
3BRPOPLPUSH source destination timeout从列表中弹出值,将其推送到另一个列表并返回它; 或阻塞,直到一个可用
4LINDEX key index通过其索引从列表获取元素
5LINSERT key BEFORE/AFTER pivot value在列表中的另一个元素之前或之后插入元素
6LLEN key获取列表的长度
7LPOP key删除并获取列表中的第一个元素
8LPUSH key value1 [value2]将一个或多个值添加到列表
9LPUSHX key value仅当列表存在时,才向列表添加值
10LRANGE key start stop从列表中获取一系列元素
11LREM key count value从列表中删除元素
12LSET key index value通过索引在列表中设置元素的值
13LTRIM key start stop修剪列表的指定范围
14RPOP key删除并获取列表中的最后一个元素
15RPOPLPUSH source destination删除列表中的最后一个元素,将其附加到另一个列表并返回
16RPUSH key value1 [value2]将一个或多个值附加到列表
17RPUSHX key value仅当列表存在时才将值附加到列表
redisTemplate.opsForList().leftPush(key, value);//从左向右存压栈

redisTemplate.opsForList().leftPop(key);//从左出栈

redisTemplate.opsForList().size(key);//队/栈长

redisTemplate.opsForList().range(key, start, end);//范围检索,返回List

redisTemplate.opsForList().remove(key, i, value);//移除key中值为value的i个,返回删除的个数;如果没有这个元素则返回0 

redisTemplate.opsForList().index(key, index);//检索

redisTemplate.opsForList().set(key, index, value);//赋值

redisTemplate.opsForList().trim(key, start, end);//裁剪,void,删除除了[start,end]以外的所有元素

redisTemplate.opsForList().rightPopAndLeftPush(String sourceKey, String destinationKey);//将源key的队列的右边的一个值删除,然后塞入目标key的队列的左边,返回这个值

注意:要缓存的对象必须实现Serializable接口,因为Spring会将对象先序列化再存入Redis,否则报异常nested exception is java.lang.IllegalArgumentException: DefaultSerializer requires a Serializable……

Set

RedisSetString类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。

集合对象的编码可以是intset或者hashtable

Redis中集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)

集合中最大的成员数为:
2 32 ? 1 2^{32}-1 232?1
个 (4294967295, 每个集合可存储40多亿个成员)。

编号命令描述说明
1SADD key member1 [member2]将一个或多个成员添加到集合
2SCARD key获取集合中的成员数
3SDIFF key1 [key2]减去多个集合
4SDIFFSTORE destination key1 [key2]减去多个集并将结果集存储在键中
5SINTER key1 [key2]相交多个集合
6SINTERSTORE destination key1 [key2]交叉多个集合并将结果集存储在键中
7SISMEMBER key member判断确定给定值是否是集合的成员
8SMOVE source destination member将成员从一个集合移动到另一个集合
9SPOP key从集合中删除并返回随机成员
10SRANDMEMBER key [count]从集合中获取一个或多个随机成员
11SREM key member1 [member2]从集合中删除一个或多个成员
12SUNION key1 [key2]添加多个集合
13SUNIONSTORE destination key1 [key2]添加多个集并将结果集存储在键中
14SSCAN key cursor [MATCH pattern] [COUNT count]递增地迭代集合中的元素
redisTemplate.opsForValue().getAndSet(key, value)
文章来源:https://blog.csdn.net/qq_37726813/article/details/135038054
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。