首页 > 数据库 >Java连接redis的工具类

Java连接redis的工具类

时间:2023-02-10 15:35:00浏览次数:50  
标签:Java String redis value param key return 连接 redisTemplate

import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.stereotype.Component;

import javax.annotation.Resource;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.TimeUnit;

/**
 * RedisManager 操作类
 * 使用SpringDataRedis进行整合
 *
 * @author yy
 * @since 1.0.0, 2019年08月20日
 */
@Component
public class RedisManager {

    @Resource
    private StringRedisTemplate redisTemplate;

    /*
     * 一、Key 键操作
     */

    /**
     * 实现命令:TTL key,以秒为单位,返回给定 key的剩余生存时间(TTL, time to live)。
     *
     * @param key 要操作的Key
     * @return 剩余生存秒数
     */
    public long ttl(String key) {
        return redisTemplate.getExpire(key);
    }

    /**
     * 实现命令:expire 设置过期时间,单位:秒
     *
     * @param key     要操作的Key
     * @param timeout 过期时间,单位:秒
     * @return 操作是否成功
     */
    public Boolean expire(String key, long timeout) {
        return redisTemplate.expire(key, timeout, TimeUnit.SECONDS);
    }

    /**
     * 实现命令:INCR key
     * 将 key 中储存的数字值增一个值delta
     *
     * @param key   key值
     * @param delta 对应增加的量
     * @return 执行完成后Value的值
     */
    public long incr(String key, long delta) {
        return redisTemplate.opsForValue().increment(key, delta);
    }

    /**
     * 实现命令:KEYS pattern
     * 查找所有符合给定模式 pattern的 key
     *
     * @param pattern 去匹配的模式
     * @return 匹配的结果
     */
    public Set<String> keys(String pattern) {
        return redisTemplate.keys(pattern);
    }

    /**
     * 实现命令:DEL key,删除一个key
     *
     * @param key 要删除的KEY
     * @return 是否操作成功
     */
    public Boolean del(String key) {
        return redisTemplate.delete(key);
    }

    /*
     * 二、String(字符串)操作
     */

    /**
     * 实现命令:SET key value,设置一个key-value(将字符串值 value关联到 key)
     *
     * @param key   对应要保存的key
     * @param value 要保存的value值
     */
    public void set(String key, String value) {
        redisTemplate.opsForValue().set(key, value);
    }

    /**
     * 实现命令:SET key value EX seconds
     * 设置key-value和超时时间(秒)
     *
     * @param key     对应要保存的key
     * @param value   对应的value值
     * @param timeout 超时时间(以秒为单位)
     */
    public void set(String key, String value, long timeout) {
        redisTemplate.opsForValue().set(key, value, timeout, TimeUnit.SECONDS);
    }

    /**
     * 实现命令:GET key,返回 key所关联的字符串值。
     *
     * @param key 对应需要查询的key
     * @return value key对应的value值
     */
    public String get(String key) {
        return redisTemplate.opsForValue().get(key);
    }

    /*
     * 三、Hash(哈希表)操作
     */

    /**
     * 实现命令:HSET key field value,
     * 将哈希表 key中的域 field的值设为 value
     *
     * @param key   对应要设置的key
     * @param field 对应hash中的字段名称
     * @param value 要设置的值
     */
    public void hset(String key, String field, Object value) {
        redisTemplate.opsForHash().put(key, field, value);
    }

    /**
     * 实现命令:HGET key field,返回哈希表 key中给定域 field的值
     *
     * @param key   对应要的key值
     * @param field 对应hash中的字段名称
     * @return 获取的结果
     */
    public String hget(String key, String field) {
        return (String) redisTemplate.opsForHash().get(key, field);
    }

    /**
     * 实现命令:HDEL key field [field ...],删除哈希表 key 中的一个或多个指定域,不存在的域将被忽略。
     *
     * @param key    对应要的key值
     * @param fields 对应要删除的字段数据-可变长参数列表
     * @return 成功删除了几个属性
     */
    public Long hdel(String key, Object... fields) {
        return redisTemplate.opsForHash().delete(key, fields);
    }

    /**
     * 实现命令:HGETALL key,返回哈希表 key中,所有的域和值。
     *
     * @param key 对应要获取的hash的key值
     * @return key对应的查询结果,hash整体
     */
    public Map<Object, Object> hgetall(String key) {
        return redisTemplate.opsForHash().entries(key);
    }

    /*
     * 四、List(列表)
     */

    /**
     * 实现命令:LPUSH key value
     * 将一个值 value插入到列表 key的表头
     *
     * @param key   对应要加的节点Key值
     * @param value 要添加的value
     * @return 执行 LPUSH命令后,列表的长度。
     */
    public long lpush(String key, String value) {
        return redisTemplate.opsForList().leftPush(key, value);
    }

    /**
     * 实现命令:LPOP key,
     * 移除并返回列表 key的头元素。
     *
     * @param key 要移除的对象
     * @return 列表key的头元素。
     */
    public String lpop(String key) {
        return redisTemplate.opsForList().leftPop(key);
    }

    /**
     * 实现命令:RPUSH key value,
     * 将一个值 value插入到列表 key的表尾(最右边)。
     *
     * @param key   要插入的key值
     * @param value 要插入的value值
     * @return 执行 LPUSH命令后,列表的长度。
     */
    public long rpush(String key, String value) {
        return redisTemplate.opsForList().rightPush(key, value);
    }


}

 

标签:Java,String,redis,value,param,key,return,连接,redisTemplate
From: https://www.cnblogs.com/RedOrange/p/17091564.html

相关文章

  • linux篇-xshell连接突然报Connection closed by foreign host.
    1问题描述报错Connectionclosedbyforeignhost.Disconnectedfromremotehost(yaoGS)at155513.2登入虚拟机在linux系统操作中,经常需要连接其他的主机,连接其他主机......
  • 4种 Redis 集群方案及优缺点对比
    4种Redis集群方案及优缺点对比在服务开发中,单机都会存在单点故障的问题,及服务部署在一台服务器上,一旦服务器宕机服务就不可用,所以为了让服务高可用,分布式服务就出......
  • oasys系统_JAVA代码审计
    oasys系统_JAVA代码审计一、前言oasys是一个OA办公自动化系统,使用Maven进行项目管理,基于springboot框架开发的项目。可以看到该项目的资源文件中是mappers且pom.xml里有M......
  • java 存在连续三个奇数的数组
    说明给你一个整数数组arr,请你判断数组中是否存在连续三个元素都是奇数的情况:如果存在,请返回true;否则,返回false。 代码 publicbooleanthreeConsecutiveOdds(......
  • 浏览器中的JavaScript(2)
    2.2注册事件处理程序摘要:有两种事件处理程序的方式。第一种是web早期就有的,及设置作为事件的对象或文档元素的一个属性。第二种方法是把处理程序传给这个元素或对象或元......
  • 项目搭建碰到java.lang.NoClassDefFoundError
    基本都是pom依赖包冲突导致的,可以这样来解决:找到pom.xml找到依赖项   一般ClassNotfound会给一个具体的类名。搜索这个类名,看是在那个pom里面。然后在pom依赖项......
  • java logAdaper日志适配器
    组件开发中日志的引入。#LogAdapter:log适配器##依赖Spring中有一个依赖:spring-jcl.jar用于适配日志框架。类名为:org.apache.commons.logging.LogAdapter<depe......
  • java中的setLayOut(null)怎么理解
    我们都知道,当我们创建好一个新的窗口后,我们要在这个窗口上面添加组件但是当我们新建了一个Panel实例并且对它使用setBound()方法后运行出来的结果与我们的预期有很大出入,那......
  • Java使用代码调用接口http根据ip访问
    HttpClient的主要功能:实现了所有HTTP的方法(GET、POST、PUT、HEAD、DELETE、HEAD、OPTIONS等)支持HTTPS协议支持代理服务器(Nginx等)等支持自动(跳转)转向详细使用示例声......
  • Java多线程06——JUC并发包02
    1线程的同步工具类​​CountDownLatch​​​​CountDownLatch​​同步辅助类,在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待。​​CountDownLatch......