redisTemplate方法区别

2020-12-21 18:01发布

rediesTemplate.bound系列方法与redisTemplate.opsFor系列的方法有什么区别

rediesTemplate.bound系列方法与redisTemplate.opsFor系列的方法有什么区别

4条回答
想减肥的小徐
1楼 · 2020-12-22 09:01.采纳回答

opsForXXX为value的类型,获取一个operator,但是没有指定操作的对象(key),可以在一个连接(事务)内操作多个key以及对应的value;boundXXXOps获取了一个指定操作对象(key)的operator,在一个连接(事务)内只能操作这个key对应的value。

武新雨 - 一个很酷的人。
2楼 · 2020-12-22 08:51

redisTemplate.opsForValue();//操作字符串
redisTemplate.opsForHash();//操作hash
redisTemplate.opsForList();//操作list
redisTemplate.opsForSet();//操作set
redisTemplate.opsForZSet();//操作有序set

无需指教
3楼 · 2020-12-22 09:03

很多公司都将redisTemplate进行了封装,封装成业务所需要的RedisUtil工具类方便进行调用,本篇文章总结了redisTemplate常用的一些方法。


文章目录

  • Redis常用的数据类型:

  • String类型

  • Hash类型

  • List类型

  • Set类型

  • zSet类型


Redis常用的数据类型:

  • String

  • Hash

  • List

  • Set

  • zSet

  • Sorted set

String类型

判断是否有key所对应的值,有则返回true,没有则返回false

redisTemplate.hasKey(key)1

有则取出key值所对应的值

redisTemplate.opsForValue().get(key)1

删除单个key值

redisTemplate.delete(key)1

批量删除key

redisTemplate.delete(keys) //其中keys:Collection keys1

将当前传入的key值序列化为byte[]类型

redisTemplate.dump(key)1

设置过期时间

public Boolean expire(String key, long timeout, TimeUnit unit) {
    return redisTemplate.expire(key, timeout, unit);
 }123
 public Boolean expireAt(String key, Date date) {
    return redisTemplate.expireAt(key, date);
  }123

查找匹配的key值,返回一个Set集合类型

public Set getPatternKey(String pattern) {
    return redisTemplate.keys(pattern);
}123

修改redis中key的名称

 public void renameKey(String oldKey, String newKey) {
    redisTemplate.rename(oldKey, newKey);
}123

返回传入key所存储的值的类型

public DataType getKeyType(String key) {
    return redisTemplate.type(key);
}123

如果旧值存在时,将旧值改为新值

public Boolean renameOldKeyIfAbsent(String oldKey, String newKey) {
    return redisTemplate.renameIfAbsent(oldKey, newKey);
}123

从redis中随机取出一个key

redisTemplate.randomKey()1

返回当前key所对应的剩余过期时间

 public Long getExpire(String key) {
    return redisTemplate.getExpire(key);
}123

返回剩余过期时间并且指定时间单位

public Long getExpire(String key, TimeUnit unit) {
    return redisTemplate.getExpire(key, unit);
}123

将key持久化保存

public Boolean persistKey(String key) {
    return redisTemplate.persist(key);
}123

将当前数据库的key移动到指定redis中数据库当中

public Boolean moveToDbIndex(String key, int dbIndex) {
    return redisTemplate.move(key, dbIndex);
}123

设置当前的key以及value值

redisTemplate.opsForValue().set(key, value)1

设置当前的key以及value值并且设置过期时间

redisTemplate.opsForValue().set(key, value, timeout, unit)1

返回key中字符串的子字符

public String getCharacterRange(String key, long start, long end) {
    return redisTemplate.opsForValue().get(key, start, end);
}123

将旧的key设置为value,并且返回旧的key

public String setKeyAsValue(String key, String value) {
    return redisTemplate.opsForValue().getAndSet(key, value);
}123

批量获取值

 public List multiGet(Collection keys) {
    return redisTemplate.opsForValue().multiGet(keys);
 }123

在原有的值基础上新增字符串到末尾

redisTemplate.opsForValue().append(key, value)1

以增量的方式将double值存储在变量中

 public Double incrByDouble(String key, double increment) {
    return redisTemplate.opsForValue().increment(key, increment);
 }123

通过increment(K key, long delta)方法以增量方式存储long值(正值则自增,负值则自减)

public Long incrBy(String key, long increment) {
    return redisTemplate.opsForValue().increment(key, increment);
}123

如果对应的map集合名称不存在,则添加否则不做修改

Map valueMap = new HashMap();  
valueMap.put("valueMap1","map1");  
valueMap.put("valueMap2","map2");  
valueMap.put("valueMap3","map3");  
redisTemplate.opsForValue().multiSetIfAbsent(valueMap); 
12345

设置map集合到redis

Map valueMap = new HashMap();  
valueMap.put("valueMap1","map1");  
valueMap.put("valueMap2","map2");  
valueMap.put("valueMap3","map3");  
redisTemplate.opsForValue().multiSet(valueMap);  
12345

获取字符串的长度

redisTemplate.opsForValue().size(key)1

用 value 参数覆写给定 key 所储存的字符串值,从偏移量 offset 开始

redisTemplate.opsForValue().set(key, value, offset)1

重新设置key对应的值,如果存在返回false,否则返回true

redisTemplate.opsForValue().setIfAbsent(key, value)1

将值 value 关联到 key,并将 key 的过期时间设为 timeout

redisTemplate.opsForValue().set(key, value, timeout, unit)1

将二进制第offset位值变为value

redisTemplate.opsForValue().setBit(key, offset, value)1

对key所储存的字符串值,获取指定偏移量上的位(bit)

redisTemplate.opsForValue().getBit(key, offset)1

Hash类型

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

获取变量中的指定map键是否有值,如果存在该map键则获取值,没有则返回null。

redisTemplate.opsForHash().get(key, field)1

获取变量中的键值对

public Map hGetAll(String key) {
    return redisTemplate.opsForHash().entries(key);
}123

新增hashMap值

redisTemplate.opsForHash().put(key, hashKey, value)1

以map集合的形式添加键值对

public void hPutAll(String key, Map maps) {
    redisTemplate.opsForHash().putAll(key, maps);
}123

仅当hashKey不存在时才设置

public Boolean hashPutIfAbsent(String key, String hashKey, String value) {
    return redisTemplate.opsForHash().putIfAbsent(key, hashKey, value);
}123

删除一个或者多个hash表字段

public Long hashDelete(String key, Object... fields) {
    return redisTemplate.opsForHash().delete(key, fields);
}123

查看hash表中指定字段是否存在

public boolean hashExists(String key, String field) {
    return redisTemplate.opsForHash().hasKey(key, field);
}123

给哈希表key中的指定字段的整数值加上增量increment

public Long hashIncrBy(String key, Object field, long increment) {
    return redisTemplate.opsForHash().increment(key, field, increment);
}123
 public Double hIncrByDouble(String key, Object field, double delta) {
    return redisTemplate.opsForHash().increment(key, field, delta);
}123

获取所有hash表中字段

redisTemplate.opsForHash().keys(key)1

获取hash表中字段的数量

redisTemplate.opsForHash().size(key)1

获取hash表中存在的所有的值

public List hValues(String key) {
    return redisTemplate.opsForHash().values(key);
}123

匹配获取键值对,ScanOptions.NONE为获取全部键对

public Cursor> hashScan(String key, ScanOptions options) {
    return redisTemplate.opsForHash().scan(key, options);
}123

List类型

通过索引获取列表中的元素

redisTemplate.opsForList().index(key, index)1

获取列表指定范围内的元素(start开始位置, 0是开始位置,end 结束位置, -1返回所有)

redisTemplate.opsForList().range(key, start, end)1

存储在list的头部,即添加一个就把它放在最前面的索引处

redisTemplate.opsForList().leftPush(key, value)1

把多个值存入List中(value可以是多个值,也可以是一个Collection value)

redisTemplate.opsForList().leftPushAll(key, value)1

List存在的时候再加入

redisTemplate.opsForList().leftPushIfPresent(key, value)1

如果pivot处值存在则在pivot前面添加

redisTemplate.opsForList().leftPush(key, pivot, value)1

按照先进先出的顺序来添加(value可以是多个值,或者是Collection var2)

redisTemplate.opsForList().rightPush(key, value)1
redisTemplate.opsForList().rightPushAll(key, value)1

在pivot元素的右边添加值

redisTemplate.opsForList().rightPush(key, pivot, value)1

设置指定索引处元素的值

redisTemplate.opsForList().set(key, index, value)1

移除并获取列表中第一个元素(如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止)

redisTemplate.opsForList().leftPop(key)1
redisTemplate.opsForList().leftPop(key, timeout, unit)1

移除并获取列表最后一个元素

redisTemplate.opsForList().rightPop(key)1
redisTemplate.opsForList().rightPop(key, timeout, unit)1

从一个队列的右边弹出一个元素并将这个元素放入另一个指定队列的最左边

redisTemplate.opsForList().rightPopAndLeftPush(sourceKey, destinationKey)1
redisTemplate.opsForList().rightPopAndLeftPush(sourceKey, destinationKey, timeout, unit)1

删除集合中值等于value的元素(index=0, 删除所有值等于value的元素; index>0, 从头部开始删除第一个值等于value的元素; index<0>

redisTemplate.opsForList().remove(key, index, value)1

将List列表进行剪裁

redisTemplate.opsForList().trim(key, start, end)1

获取当前key的List列表长度

redisTemplate.opsForList().size(key)1

Set类型

添加元素

redisTemplate.opsForSet().add(key, values)1

移除元素(单个值、多个值)

redisTemplate.opsForSet().remove(key, values)1

删除并且返回一个随机的元素

redisTemplate.opsForSet().pop(key)1

获取集合的大小

redisTemplate.opsForSet().size(key)1

判断集合是否包含value

redisTemplate.opsForSet().isMember(key, value)1

获取两个集合的交集(key对应的无序集合与otherKey对应的无序集合求交集)

redisTemplate.opsForSet().intersect(key, otherKey)1

获取多个集合的交集(Collection var2)

redisTemplate.opsForSet().intersect(key, otherKeys)1

key集合与otherKey集合的交集存储到destKey集合中(其中otherKey可以为单个值或者集合)

redisTemplate.opsForSet().intersectAndStore(key, otherKey, destKey)1

key集合与多个集合的交集存储到destKey无序集合中

redisTemplate.opsForSet().intersectAndStore(key, otherKeys, destKey)1

获取两个或者多个集合的并集(otherKeys可以为单个值或者是集合)

redisTemplate.opsForSet().union(key, otherKeys)1

key集合与otherKey集合的并集存储到destKey中(otherKeys可以为单个值或者是集合)

redisTemplate.opsForSet().unionAndStore(key, otherKey, destKey)1

获取两个或者多个集合的差集(otherKeys可以为单个值或者是集合)

redisTemplate.opsForSet().difference(key, otherKeys)1

差集存储到destKey中(otherKeys可以为单个值或者集合)

redisTemplate.opsForSet().differenceAndStore(key, otherKey, destKey)1

随机获取集合中的一个元素

redisTemplate.opsForSet().randomMember(key)1

获取集合中的所有元素

redisTemplate.opsForSet().members(key)1

随机获取集合中count个元素

redisTemplate.opsForSet().randomMembers(key, count)1

获取多个key无序集合中的元素(去重),count表示个数

redisTemplate.opsForSet().distinctRandomMembers(key, count)1

遍历set类似于Interator(ScanOptions.NONE为显示所有的)

redisTemplate.opsForSet().scan(key, options)1

zSet类型

ZSetOperations提供了一系列方法对有序集合进行操作
添加元素(有序集合是按照元素的score值由小到大进行排列)

redisTemplate.opsForZSet().add(key, value, score)1

删除对应的value,value可以为多个值

redisTemplate.opsForZSet().remove(key, values)1

增加元素的score值,并返回增加后的值

redisTemplate.opsForZSet().incrementScore(key, value, delta)1

返回元素在集合的排名,有序集合是按照元素的score值由小到大排列

redisTemplate.opsForZSet().rank(key, value)1

返回元素在集合的排名,按元素的score值由大到小排列

redisTemplate.opsForZSet().reverseRank(key, value)1

获取集合中给定区间的元素(start 开始位置,end 结束位置, -1查询所有)

redisTemplate.opsForZSet().reverseRangeWithScores(key, start,end)1

按照Score值查询集合中的元素,结果从小到大排序

redisTemplate.opsForZSet().reverseRangeByScore(key, min, max)1
redisTemplate.opsForZSet().reverseRangeByScoreWithScores(key, min, max)
//返回值为:Set>12

从高到低的排序集中获取分数在最小和最大值之间的元素

redisTemplate.opsForZSet().reverseRangeByScore(key, min, max, start, end)1

根据score值获取集合元素数量

redisTemplate.opsForZSet().count(key, min, max)1

获取集合的大小

redisTemplate.opsForZSet().size(key)1
redisTemplate.opsForZSet().zCard(key)1

获取集合中key、value元素对应的score值

redisTemplate.opsForZSet().score(key, value)1

移除指定索引位置处的成员

redisTemplate.opsForZSet().removeRange(key, start, end)1

移除指定score范围的集合成员

redisTemplate.opsForZSet().removeRangeByScore(key, min, max)1

获取key和otherKey的并集并存储在destKey中(其中otherKeys可以为单个字符串或者字符串集合)

redisTemplate.opsForZSet().unionAndStore(key, otherKey, destKey)1

获取key和otherKey的交集并存储在destKey中(其中otherKeys可以为单个字符串或者字符串集合)

redisTemplate.opsForZSet().intersectAndStore(key, otherKey, destKey)1

遍历集合(和iterator一模一样)

Cursor> scan = opsForZSet.scan("test3", ScanOptions.NONE);
        while (scan.hasNext()){
            ZSetOperations.TypedTuple item = scan.next();
            System.out.println(item.getValue() + ":" + item.getScore());
        }


可口可乐
4楼 · 2021-02-22 10:02

opsForXXX为value的类型,获取一个operator,但是没有指定操作的对象(key),可以在一个连接(事务)内操作多个key以及对应的value;boundXXXOps获取了一个指定操作对象(key)的operator,在一个连接(事务)内只能操作这个key对应的value。

相关问题推荐

  • 回答 27

    DDL      create table 创建表    alter table  修改表   drop table 删除表   truncate table 删除表中所有行    create index 创建索引   drop index  删除索引 当执行DDL语句时,在每一条语句前后,oracle都将提交当前的事...

  • 回答 23

    java开发应用数据库比较主流的有下面这三种:    1.MySQL   MySQL是最受欢迎的开源SQL数据库管理系统,它由MySQL AB开发、发布和支持。MySQL AB是一家基于MySQL开发人员的商业公司,它是一家使用了一种成功的商业模式来结合开源价值和方法论的第二代开...

  • 回答 23

    1,DML(DataManipulationLanguage):数据操作语言,用来定义数据库记录(数据)2,DCL(DataControlLanguage):数据控制语言,用来定义访问权限和安全级别;3,DQL(DataQueryLanguage):数据查询语言,用来查询记录(数据);4,DDL(DataDefinitionLang...

  • 回答 11

    数据库三级模式:1、外模式,外模式又称子模式或用户模式,对应于用户级,外模式是从模式导出的一个子集,包含模式中允许特定用户使用的那部分数据。用户可以通过外模式描述语言来描述、定义对应于用户的数据记录(外模式),也可以利用数据操纵语言(Data Manip...

  • 回答 11

    模式、外模式、内莫斯,亦称逻辑模式,是数据库中全体数据的逻辑结构和特征的描述,是所有用户的公共数据视图。模式描述的是数据的全局逻辑结构。 外模式涉及的是数据的局部逻辑结构,通常是模式的子集 内模式,亦称存储模式,是数据库在数据系统内部的表示...

  • 回答 16

    为了避免上面出现的几种情况,在标准SQL规范中,定义了4个事务隔离级别,不同的隔离级别对事务的处理不同。未授权读取(Read Uncommitted):允许脏读取,但不允许更新丢失。如果一个事务已经开始写数据,则另外一个数据则不允许同时进行写操作,但允许其他事...

  • 回答 5

    from是个关键词,表示要从哪个表查询。。

  • 回答 12

    数据库池连接数量一直保持一个不少于最小连接数的数量,当数量不够时,数据库会创建一些连接,直到一个最大连接数,之后连接数据库就会等待。

  • 回答 7

    仅用慢日志文件,如何快速获取分时报告?如果有监控系统,获取分时报告(每小时慢查询的条数报告)不难,如果只有慢日志文件,就会有点费劲。实验:通过 pt-query-digest --timeline 功能,可以输出带时间戳的慢查询条目用 sed 将 timeline 报告滤出安装 term...

  • 回答 9
    已采纳

    MySql优化的一般步骤:1.通过show status 命令了解各种sql的执行效率  SHOW STATUS提供msyql服务器的状态信息  一般情况下,我们只需要了解以Com开头的指令  show session status like ‘Com%’:显示当前的连接的统计结果  show global status like ...

  • 回答 4

    有可能是你输入的密码有问题,如果你的密码字母在前数字在后,那么你输入前面的字母后敲回车再输入数字就可以了,可以试一下

  • 回答 5

    工程目录sql语句CREATE TABLE `user` (  `id` int(11) NOT NULL AUTO_INCREMENT,  `username` varchar(32) NOT NULL COMMENT '用户名称',  `birthday` date DEFAULT NULL COMMENT '生日',  `sex` char(1) DEFAUL...

  • 回答 6

    事实上MySQL 能承受的数据量的多少主要和数据表的结构有关,并不是一个固定的数值。表的结构简单,则能承受的数据量相对比结构复杂时大些。据D.V.B 团队以及Cmshelp 团队做CMS 系统评测时的结果来看,MySQL单表大约在2千万条记录(4G)下能够良好运行,经过数...

  • 回答 5

    事实上MySQL 能承受的数据量的多少主要和数据表的结构有关,并不是一个固定的数值。表的结构简单,则能承受的数据量相对比结构复杂时大些。据D.V.B 团队以及Cmshelp 团队做CMS 系统评测时的结果来看,MySQL单表大约在2千万条记录(4G)下能够良好运行,经过数...

  • 回答 6

    mysql哪个版本比较稳定MySQL的选择要取决于用途的,mysql5.5或者5.7 的版本,网上资源较多mysql的版本如下:1. MySQL Community Server 社区版本,开源免费,但不提供官方技术支持。2. MySQL Enterprise Edition 企业版本,需付费,可以试用30天。3. MySQL C...

  • 回答 4

    事实上MySQL 能承受的数据量的多少主要和数据表的结构有关,并不是一个固定的数值。表的结构简单,则能承受的数据量相对比结构复杂时大些。据D.V.B 团队以及Cmshelp 团队做CMS 系统评测时的结果来看,MySQL单表大约在2千万条记录(4G)下能够良好运行,经过数...

没有解决我的问题,去提问