基础配置介绍已经在前面的《RedisTemplate常用集合使用说明(一)》中已经介绍了,现在我们直接介绍opsForHash()方法的使用:
1、put(H key,
HK hashKey,
HV value)
新增hashMap值。
redisTemplate.opsForHash().put("hashValue","map1","map1-1"); redisTemplate.opsForHash().put("hashValue","map2","map2-2");
2、values(H key)
获取指定变量中的hashMap值。
List<Object> hashList = redisTemplate.opsForHash().values("hashValue"); System.out.println("通过values(H key)方法获取变量中的hashMap值:" + hashList);
3、entries(H key)
获取变量中的键值对。
Map<Object,Object> map = redisTemplate.opsForHash().entries("hashValue"); System.out.println("通过entries(H key)方法获取变量中的键值对:" + map);
4、get(H key, Object hashKey)
获取变量中的指定map键是否有值,如果存在该map键则获取值,没有则返回null。
Object mapValue = redisTemplate.opsForHash().get("hashValue","map1"); System.out.println("通过get(H key, Object hashKey)方法获取map键的值:" + mapValue);
5、hasKey(H key,
Object hashKey)
判断变量中是否有指定的map键。
boolean hashKeyBoolean = redisTemplate.opsForHash().hasKey("hashValue","map3"); System.out.println("通过hasKey(H key, Object hashKey)方法判断变量中是否存在map键:" + hashKeyBoolean);
6、keys(H key)
获取变量中的键。
Set<Object> keySet = redisTemplate.opsForHash().keys("hashValue"); System.out.println("通过keys(H key)方法获取变量中的键:" + keySet);
7、size(H key)
获取变量的长度。
long hashLength = redisTemplate.opsForHash().size("hashValue"); System.out.println("通过size(H key)方法获取变量的长度:" + hashLength);
8、increment(H key, HK hashKey, double delta)
使变量中的键以double值的大小进行自增长。
double hashIncDouble = redisTemplate.opsForHash().increment("hashInc","map1",3); System.out.println("通过increment(H key, HK hashKey, double delta)方法使变量中的键以值的大小进行自增长:" + hashIncDouble);
9、increment(H key, HK hashKey, long delta)
使变量中的键以long值的大小进行自增长。
long hashIncLong = redisTemplate.opsForHash().increment("hashInc","map2",6); System.out.println("通过increment(H key, HK hashKey, long delta)方法使变量中的键以值的大小进行自增长:" + hashIncLong);
10、multiGet(H key,
Collection<HK> hashKeys)
以集合的方式获取变量中的值。
List<Object> list = new ArrayList<Object>(); list.add("map1"); list.add("map2"); List mapValueList = redisTemplate.opsForHash().multiGet("hashValue",list); System.out.println("通过multiGet(H key, Collection<HK> hashKeys)方法以集合的方式获取变量中的值:"+mapValueList);
11、putAll(H key, Map<? extends HK,? extends HV> m)
以map集合的形式添加键值对。
Map newMap = new HashMap(); newMap.put("map3","map3-3"); newMap.put("map5","map5-5"); redisTemplate.opsForHash().putAll("hashValue",newMap); map = redisTemplate.opsForHash().entries("hashValue"); System.out.println("通过putAll(H key, Map<? extends HK,? extends HV> m)方法以map集合的形式添加键值对:" + map);
12、putIfAbsent(H key, HK hashKey, HV value)
如果变量值存在,在变量中可以添加不存在的的键值对,如果变量不存在,则新增一个变量,同时将键值对添加到该变量。
redisTemplate.opsForHash().putIfAbsent("hashValue","map6","map6-6"); map = redisTemplate.opsForHash().entries("hashValue"); System.out.println("通过putIfAbsent(H key, HK hashKey, HV value)方法添加不存在于变量中的键值对:" + map);
13、scan(H key, ScanOptions options)
匹配获取键值对,ScanOptions.NONE为获取全部键对,ScanOptions.scanOptions().match("map1").build() 匹配获取键位map1的键值对,不能模糊匹配。
Cursor<Map.Entry<Object,Object>> cursor = redisTemplate.opsForHash().scan("hashValue",ScanOptions.scanOptions().match("map1").build()); //Cursor<Map.Entry<Object,Object>> cursor = redisTemplate.opsForHash().scan("hashValue",ScanOptions.NONE); while (cursor.hasNext()){ Map.Entry<Object,Object> entry = cursor.next(); System.out.println("通过scan(H key, ScanOptions options)方法获取匹配键值对:" + entry.getKey() + "---->" + entry.getValue()); }
14、delete(H key, Object... hashKeys)
删除变量中的键值对,可以传入多个参数,删除多个键值对。
redisTemplate.opsForHash().delete("hashValue","map1","map2"); map = redisTemplate.opsForHash().entries("hashValue"); System.out.println("通过delete(H key, Object... hashKeys)方法删除变量中的键值对后剩余的:" + map);
相关推荐
`RedisTemplate`提供了丰富的API,包括`opsForHash()`, `opsForList()`, `opsForSet()` 和 `opsForZSet()` 等,分别对应Redis的哈希、列表、集合和有序集合操作。这使得在Spring应用中操作Redis变得非常方便。 总之...
- 操作哈希:`Map, String> map = redisTemplate.opsForHash().entries(hashKey);` 8. **最佳实践** - 分布式锁:使用Redis实现分布式锁,解决多线程并发问题。 - 分页查询:利用有序集合进行分页,避免重复计算...
这个压缩包文件“SpringDataRedis对Redis的数据类型的常用操作API的使用代码举例.zip”显然包含了关于如何利用Spring Data Redis进行Redis数据类型操作的示例代码。下面我们将深入探讨Spring Data Redis对Redis主要...
5. **RedisTemplate的常用方法** - `opsForValue()`:操作单个值,如设置、获取、增加、减少等。 - `opsForHash()`:操作哈希,支持添加、删除、获取键值对等。 - `opsForList()`:操作列表,进行插入、删除、...
此外,文档可能还会提醒开发者注意Redis的数据类型(如字符串、哈希、列表、集合、有序集合),以及如何通过`RedisTemplate`操作这些数据类型。例如,使用`opsForHash()`操作哈希数据,使用`opsForList()`操作列表等...
例如,使用RedisTemplate的opsForHash()进行哈希操作,使用opsForList()处理列表数据,或者使用opsForSet()管理集合数据。同时,为了提高并发性能和数据一致性,可以引入Redlock或分布式锁策略。 在提供的压缩包...
4. **RedisTemplate的使用**:RedisTemplate提供了丰富的操作方法,如`opsForValue()`用于操作字符串,`opsForHash()`处理哈希,`opsForSet()`处理集合,`opsForZSet()`处理有序集合等。这些操作方法都支持泛型,能...
在IT行业中,Redis是一款广泛应用的高性能键值存储系统,它以数据结构服务器的形式工作,支持字符串、哈希、列表、集合、有序集合等多种数据结构。Spring Data Redis是Spring框架为Redis提供的一套全面的整合库,它...
例如,可以使用 `opsForValue()` 方法存取字符串类型的数据,使用 `opsForHash()` 处理哈希类型的数据。 6. 配置缓存注解:Spring 提供了 `@Cacheable`、`@CacheEvict` 和 `@CachePut` 等注解,可以直接在方法上...
3. **创建RedisTemplate Bean**:SpringBoot自动配置了`StringRedisTemplate`,但若需自定义配置,可以创建`RedisTemplate` Bean,设置序列化器等选项。 接下来,我们关注Redis工具类的实现,这通常包含以下功能: ...
1. **数据结构丰富**:Redis支持多种数据类型,如字符串(Strings)、哈希(Hashes)、列表(Lists)、集合(Sets)和有序集合(Sorted Sets),这些数据结构设计灵活,满足各种业务场景需求。 2. **内存存储**:Redis将所有...
例如,`opsForHash()`、`opsForValue()`等方法提供了对哈希、字符串、集合、有序集合的操作。 6. **Redis集群支持** 集成Redis集群时,需在配置中指定集群节点的地址,并启用集群模式。Lettuce客户端会自动处理...
`opsForValue()`用于操作字符串类型数据,`opsForHash()`处理哈希类型,`opsForSet()`管理集合,而`opsForList()`则用于列表类型的数据操作。 5. 在Maven的pom.xml文件中,排除依赖的标签是`<exclusions>`,可以...
redisTemplate.opsForHash().put(key, field, JSON.toJSONString(value)); } // 获取哈希中的所有字段 public Map, Object> hGetAll(String key) { return redisTemplate.opsForHash().entries(key); } // 其他...
3. **使用 RedisTemplate 或 StringRedisTemplate**: SpringBoot 会自动配置 RedisTemplate 和 StringRedisTemplate,你可以通过它们进行数据的存取操作。例如,存储字符串键值对: ```java @Autowired private ...