RedisTemplate - 常用集合之bound...Ops系列

本文详细介绍了RedisTemplate中与Redis数据结构相关的boundValueOps、boundHashOps、boundListOps、boundSetOps和boundZSetOps的常用方法,包括set、get、put、remove等操作,并提供了实例说明其用途和注意事项。文章还提到,所有的键值对可以通过delete进行删除。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、boundValueOps

简单的Key-Value操作。

1、BoundValueOperations

BoundValueOperations就是一个绑定key的对象,我们可以通过这个对象来进行与key相关的操作。

BoundValueOperations boundValueOps = redisTemplate.boundValueOps("lcy");
2、set(V value)

给绑定键重新设置值(如果没有值,则会添加这个值)。

boundValueOps.set("柳成荫");
3、get()

获取绑定键的值。

String str = (String) boundValueOps.get();
System.out.println(str);
4、set(V value, long timeout, TimeUnit unit)

给绑定键设置新值并设置过期时间

boundValueOps.set("九月清晨",30, TimeUnit.SECONDS);
5、getAndSet(V value)
String oldValue = (String) boundValueOps.getAndSet("寻宝游戏");
String newValue = (String) boundValueOps.get();
6、increment(double delta)increment(long delta)

它是Redis的自增长键,前提是绑定值的类型是doublelong类型。increment是单线程的,所以它是安全的。在我另外一篇学习博客《秒杀系统》有用到该特性。

BoundValueOperations boundValueOps = redisTemplate.boundValueOps("jyqc");
boundValueOps.set(1);
System.out.println(boundValueOps.get());
boundValueOps.increment(1);
System.out.println(boundValueOps.get());
boundValueOps.increment(1);
System.out.println(boundValueOps.get());

使用该方法,需要注意:需要使用StringRedisSerializer序列化器才能使用increment方法,否则会报错。

7、其他不常用的方法

其他不常用的方法可以参考:boundValueOps的使用

二、boundHashOps

针对hash的相关操作。

1、BoundHashOperations

BoundHashOperations就是一个绑定key的对象,我们可以通过这个对象来进行与key相关的操作。

BoundHashOperations boundHashOps = redisTemplate.boundHashOps("user");
2、put(HK key, HV value)

新增元素到指定键中。

boundHashOps.put("lcy","柳成荫");
boundHashOps.put("jyqc","九月清晨");
3、get(Object member)

获取绑定键中的成员键对应的值value

// 这里打印的结果也就是 九月清晨
System.out.println(boundHashOps.get("jyqc"));
4、getKey()

获取指定键绑定的key值

// 这里也就是之前绑定的那个user
System.out.println(boundHashOps.getKey());
5、keys()

获取绑定键的key集合

// [lcy,jyqc]
Set keys = boundHashOps.keys();
6、values()

获取绑定键中的所有key对应的值

// [柳成荫,九月清晨]
List values = boundHashOps.values();
7、entries()

获取绑定键中的键值对

Map entries = boundHashOps.entries();
8、putAll(Map<? extends HK,? extends HV> m)

批量添加键值对。

map.put("xbyx","寻宝游戏");
map.put("brccq","不如吃茶去");
boundHashOps.putAll(map);
9、increment(HK key, long delta)

Redis的自增长特性,在Hash下的用法。

 boundHashOps.increment("qnwb",1);
boundHashOps.increment("qnwb",1);
Long inc = (Long) boundHashOps.get("qnwb");
10、其他不常用的方法

其他不常用的方法可以参考:boundHashOps的用法

三、boundListOps

针对list的相关操作。

1、BoundListOperations

BoundListOperations就是一个绑定key的对象,我们可以通过这个对象来进行与key相关的操作。

BoundListOperations boundListOps = redisTemplate.boundListOps("lcy");
2、leftPush(V value)

在绑定键中左边添加值

// [c,b,a]
boundListOps .leftPush("a");
boundListOps .leftPush("b");
boundListOps .leftPush("c");
3、leftPop()

从左边弹出值。

System.out.println(boundListOps.leftPop());

既然有左边的操作,那肯定也有右边的操作,即把上诉方法的left改成right即可。

4、range(long start, long end)

获取绑定键中给定的区间值,从下标0开始,end可以为-1表示最后一位。

List range = boundListOps.range(0, -1);
5、index(long index)

获取给定位置的值,从下标0开始

boundListOps.index(2);
6、其他方法的使用

其他的方法可以参考:boundListOps的用法

四、boundSetOps

针对Set的相关操作。

1、BoundSetOperations

BoundSetOperations就是一个绑定key的对象,我们可以通过这个对象来进行与key相关的操作。

BoundSetOperations boundSetOps = redisTemplate.boundSetOps("lcy");
2、add(V… values)

批量添加值,可以是集合数组多参数

boundSetOps .add("a","b","c");
3、members()

获取所有值。

Set members = boundSetOps.members();
4、randomMember()、randomMembers(long count)

随机获取一个值、随机获取count个值

Object o = boundSetOps.randomMember();
List list = boundSetOps.randomMembers(5);
5、pop()

弹出集合中的值。

Object o = boundSetOps.pop();
6、remove(Object… values)

批量移除元素,可以是集合数组多参数

boundSetOps.remove("c")
7、其他不常用的方法

其他不常用的方法可以参考:boundSetOps的用法

五、boundZSetOps

针对ZSet的相关操作。

1、BoundZSetOperations

BoundZSetOperations就是一个绑定key的对象,我们可以通过这个对象来进行与key相关的操作。

BoundZSetOperations boundZSetOps = redisTemplate.boundZSetOps("lcy");
2、add(V value, double score)

绑定键中添加值,同时指定值的分数。

boundZSetOps .add("a",1);
boundZSetOps .add("b",2);
3、range(long start, long end)

获取绑定键的指定区间值。

Set range = boundZSetOps.range(0, -1);
4、remove(Object… values)

按值批量删除绑定键中的元素,可以是集合数组多参数

boundZSetOps.remove(list);
5、其他不常用的方法

其他不常用的方法可以参考:boundZSetOps的用法

六、所有的键值对都可以通过delete删除

// 删除一个Key
redisTemplate.delete("hashKey");
// 删除多个Key - 可以是集合、数组、多参数
redisTemplate.delete(list);
### 回答1: mybatis-plus是MyBatis的一个增强工具,它提供了更多的功能和便利的操作,使得使用MyBatis更加方便快捷。 而org.apache.ibatis.binding.BindingException: invalid bound statement异常表示在执行数据库操作时,绑定了一个无效的MyBatis语句。 造成该异常的原因可能是: 1. 未在对应的Mapper接口中定义该方法对应的SQL语句。 2. 方法名与Mapper接口中定义的方法名不一致,导致找不到对应的SQL语句。 3. 找不到对应的Mapper接口。 解决该异常的方法: 1. 确保在Mapper接口中定义了所有需要执行的SQL语句,且方法名与对应的SQL语句有一致的命名规则。 2. 检查方法名与Mapper接口中定义的方法名是否一致。 3. 检查Mapper接口的包路径,确保MyBatis能够正确地扫描到该接口。 如果以上方法都检查了,但还是无法解决该异常,可以尝试重新导入mybatis-plus依赖或者对其版本进行升级,也可以查看具体的异常信息,以便更加准确定位到问题所在。 总之,org.apache.ibatis.binding.BindingException: invalid bound statement异常是由于绑定了一个无效的MyBatis语句所导致的,需要检查对应的Mapper接口和SQL语句是否正确。 ### 回答2: mybatis-plus是一个基于mybatis的增强工具,可以简化mybatis的使用,提供了很多便捷的功能。然而,当出现"org.apache.ibatis.binding.BindingException: Invalid bound statement"错误时,通常是由于绑定的SQL语句在mybatis-plus中未找到或错误的引用导致的。 出现这个错误可能有几种原因,首先需要确认绑定的SQL语句是否正确,包括SQL语句的拼写、参数的传递等。 另外,如果使用的是mybatis-plus自动生成的mapper接口,需要检查该接口是否正确继承了mybatis-plus提供的基础接口(如BaseMapper),并且调用的方法名与mapper接口定义的方法名保持一致。 还可能是由于配置文件的问题引起的,需要检查mybatis的配置文件(通常是mybatis-config.xml)中是否正确配置了mapper的包扫描路径和mapper的引用等。 如果以上都检查无误,仍然无法解决问题,可以通过查看具体的错误堆栈信息,定位到出错的位置,进一步分析和排查问题。如果有必要,可以上网搜索类似问题的解决方案,或者向社区寻求帮助。 总之,mybatis-plus的"org.apache.ibatis.binding.BindingException: Invalid bound statement"错误通常是由于SQL语句未找到或错误的引用导致的,通过检查SQL语句、接口的继承关系、配置文件等多个方面,可以解决这个问题。 ### 回答3: mybatis-plus org.apache.ibatis.binding.BindingException: invalid bound statement 这个错误通常表示在MyBatis-Plus中的代码中存在无效的绑定语句。具体来说,可能是因为以下原因之一: 1. XML文件中的命名空间或语句ID错误:请确保在mybatis-plus-config.xml或mapper.xml中定义的命名空间和语句ID是正确的。检查是否存在拼写错误或命名空间与语句ID之间的对应关系错误。 2. 语句ID不存在:请检查在代码中是否正确引用了存在的语句ID。如果在mapper.xml文件中没有定义相应的语句,或者语句ID错误,则会出现此错误。 3. mapper接口方法名称错误:如果使用的是mapper接口与XML映射方式,确保在Java接口中定义的方法名称与mapper.xml中定义的语句ID相匹配。如果方法名称错误,会导致无法找到对应的绑定语句。 4. SQL语句错误:检查在mapper.xml中定义的SQL语句是有效的。注意SQL语法是否正确,表名和列名是否正确,以及是否有无效的SQL语句。 5. 配置文件错误:检查mybatis-plus-config.xml中是否存在配置错误。例如,检查是否正确配置了数据库连接信息以及其他必要的配置项。 综上所述,要解决这个错误,需要逐一检查以上几个方面的可能原因,并予以纠正。确认命名空间、语句ID、方法名称等是否正确,检查SQL语句的准确性,并确保配置文件中的配置正确。通过排查和修复以上问题,可以解决该错误并使代码正常运行。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值