教你怎么用Java操作Redis

首先让我们创建一个普通的Maven工程,添加相应的依赖

<dependencies>
		<dependency>
		    <groupId>redis.clients</groupId>
		    <artifactId>jedis</artifactId>
		    <version>3.3.0</version>
		</dependency>

		<dependency>
			<groupId>com.alibaba</groupId>
			<artifactId>fastjson</artifactId>
			<version>1.2.72</version>
		</dependency>
  </dependencies>

然后我们就可以是使用了

测试连接(这里我用的是本地的reids服务)

//定义主机号、端口号
		HostAndPort hostAndPort = new HostAndPort("127.0.0.1",6379);
		//连接redis服务
		Jedis jedis=new Jedis(hostAndPort);
		//ping一下
		System.out.println("服务正在运行: "+jedis.ping())
		//关闭
		jedis.close();
控制台输出PONG代表连接成功

接下来让我们看看Redis的五大数据类型的基础操作

  • String类型
System.out.println("存入一个数据:"+jedis.set("age", "20"));
		System.out.println("存入多个数据:"+jedis.mset("name","zhangsan","sex","男"));

		System.out.println("获取一个数据:"+jedis.get("age"));
		System.out.println("获取多个数据:"+jedis.mget("name","sex"));

		System.out.println("将指定的字符串拼接在指定数据之后:"+jedis.append("name",",你好"));

		System.out.println("查看某个数据的长度:"+jedis.strlen("name"));

		System.out.println("修改某个数据的值并返回修改之前的值:"+jedis.getSet("name", "lisi"));

		System.out.println("判断某个数据是否存在:"+jedis.exists("name"));

		System.out.println("为某个数据设置失效时间(单位/s):"+jedis.expire("name", 20));

		System.out.println("查看某个数据的剩余生存时间(s):"+jedis.ttl("name"));

		System.out.println("删除一个或多个数据:"+jedis.del("name","sex"));

查看打印结果

  • Set类型
System.out.println("向集合添加一个或多个元素:"+jedis.sadd("key1", "v1","v2","v3"));

		System.out.println("获取集合的元素个数:"+jedis.scard("key1"));

		System.out.println("返回集合中的所有元素:"+jedis.smembers("key1"));

		System.out.println("判断指定元素是否存在集合中:"+jedis.sismember("key1", "v1"));

		System.out.println("移除集合中指定的元素:"+jedis.srem("key1", "v3"));

		//这里我们在创建一个集合
		System.out.println("向集合添加一个或多个元素:"+jedis.sadd("key2", "v2","v3","v4"));

		System.out.println("返回集合key1与key2的差集:"+jedis.sdiff("key1","key2"));
		System.out.println("返回集合key1与key2的交集:"+jedis.sinter("key1","key2"));
		System.out.println("返回集合key1与key2的并集:"+jedis.sunion("key1","key2"));

查看结果

  • Hash类型
	Map map=new HashMap<>();
		map.put("name", "zhangsan");
		map.put("age", "20");
		map.put("sex", "男");

		System.out.println("创建一个哈希表存储一个用户对象:"+jedis.hmset("user",map));

		System.out.println("获取哈希表中用户的name:"+jedis.hget("user", "name"));

		System.out.println("查看哈希表中,指定的字段是否存在:"+jedis.hexists("user", "name"));

		System.out.println("获取哈希表中字段的数量:"+jedis.hlen("user"));

		System.out.println("获取哈希表中所有字段:"+jedis.hkeys("user"));

		System.out.println("获取哈希表中所有字段的值:"+jedis.hvals("user"));

		System.out.println("获取在哈希表中的所有字段和值:"+jedis.hgetAll("user"));

		System.out.println("删除一个或多个哈希表字段:"+jedis.hdel("user","name","age","sex"));

查看结果

  • List类型
System.out.println("将一个值插入到列表头部(可以多个值):"+jedis.lpush("city","北京","上海"));

		System.out.println("将一个值插入到列表尾部(可以多个值):"+jedis.rpush("city","济南","南京"));

		System.out.println("获取列表指定范围内的元素:"+jedis.lrange("city", 0, -1));

		System.out.println("获取列表长度:"+jedis.llen("city"));

		System.out.println("移出列表的第一个元素,并输出值:"+jedis.lpop("city"));

		System.out.println("移除列表的最后一个元素,并输出值:"+jedis.rpop("city"));

		System.out.println("修改列表中指定索引位置元素的值:"+jedis.lset("city", 0, "西藏"));

		System.out.println("让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除:"+jedis.ltrim("city", 1, 2));

查看结果

  • Sorted Set类型
Map<String,Double> scoreMembers=new HashMap<>();
		scoreMembers.put("member1", 1D);
		scoreMembers.put("member2", 2D);
		scoreMembers.put("member3", 3D);

		System.out.println("向有序集合添加一个或多个元素,或者更新已存在元素的分数:"+jedis.zadd("member", scoreMembers));

		System.out.println("获取有序集合的元素个数:"+jedis.zcard("member"));

		System.out.println("计算在有序集合中指定区间([socre1,socre2])分数的成员数:"+jedis.zcount("member", 0D, 3D));

		System.out.println("通过索引区间返回有序集合指定区间内的元素,从低到高:"+jedis.zrange("member", 0,-1));

		System.out.println("返回索引区间返回有序集合指定区间内的元素,从高到低:"+jedis.zrevrange("member", 0,-1));

		System.out.println("返回有序集中指定元素的分数值:"+jedis.zscore("member", "member1"));

		System.out.println("移除有序集合中的一个或多个元素:"+jedis.zrem("member", "member1","member2"));

		System.out.println("返回有序集合中指定元素的索引:"+jedis.zrank("member", "member3"));

查看结果

最后我们简单看看如何操作数据库

	System.out.println("清空当前数据库:"+jedis.flushDB());

		System.out.println("清空所有数据库:"+jedis.flushAll());

		System.out.println("查看当前数据库存储数据的多少:"+jedis.dbSize());

		Set<String> keys = jedis.keys("*");
		System.out.println("查看当前数据库存储所有键值:"+keys);

		System.out.println("选择某个数据库:"+jedis.select(0));

查看结果

其实Redis还有三种特殊存储类型

  • Geospatial

主要用于存储地理位置信息,并对存储的信息进行操作,基于Sorts Set有序集合

  • HyperLogLog

是用来做基数统计的

  • Bitmap

通过操作二进制(0,1)来记录只有两种状态的信息

这里老哥就不测试了,这三种类型的使用在项目业务中也很常见,想了解的小伙伴可以去Redis官网看一下:Redis中文官网

最后总结一下

其实这些api方法的使用基本都是根据redis的命令封装的,也就是说什么样的redis命令基本就对应一个什么样的jedis的一个方法,很简单的!

所以说学会掌握Redis的命令是多么的重要啊,要学会一通百通!

到此这篇关于教你怎么用Java操作Redis的文章就介绍到这了,更多相关Java操作Redis内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Java操作Redis2种方法代码详解

    Java操作Redis的方式有下面两种: 一.jedis (1)maven配置 <dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> <version>2.9.0</version> </dependency> (2)相关类 单节点:redis.clients.jedis.Jedis 集群:redis.clien

  • Java操作redis实现增删查改功能的方法示例

    本文实例讲述了Java操作redis实现增删查改功能的方法.分享给大家供大家参考,具体如下: 首先,我们需要在windows下配置一个redis环境,具体配置教程请看:http://www.jb51.net/article/96230.htm 然后需要导入:jedis-2.7.3.jar这个包,看如下代码: package redis.main; import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool; imp

  • Java客户端利用Jedis操作redis缓存示例代码

    前言 Redis是一个开源的Key-Value数据缓存,和Memcached类似.Redis多种类型的value,包括string(字符串).list(链表).set(集合).zset(sorted set --有序集合)和hash(哈希类型). Jedis 是 Redis 官方首选的 Java 客户端开发包.下面就来给大家详细关于Java客户端利用Jedis操作redis缓存的相关内容,话不多说,直接来看示例代码吧. 示例代码: //连接redis ,redis的默认端口是6379 Jedis

  • 新手学习Java对Redis简单操作

    REmote DIctionary Server(Redis) 是一个由Salvatore Sanfilippo写的key-value存储系统. Redis是一个开源的使用ANSI C语言编写.遵守BSD协议.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API. 它通常被称为数据结构服务器,因为值(value)可以是 字符串(String), 哈希(Map), 列表(list), 集合(sets) 和 有序集合(sorted sets)等类型. 代码如下 首

  • Java使用Jedis操作Redis服务器的实例代码

    这几天Java项目中需要用到Redis,于是学习了一下使用Jedis来操作Redis服务器的相关知识,下面为具体的配置和代码. 1.Maven中配置Jedis 在maven项目的pom.xml中添加依赖 <dependencies> <dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> <version>2.9.0</

  • Java实现Redis的集合(set)命令操作

    配置文件请看上篇Java实现redis https://www.jb51.net/article/190922.htm 下面测试redis的集合set的类型,注释里面的代码是linux中redis命令 package com.huadian.set; import com.huadian.redisUntil.JedisPoolUntil; import org.junit.Before; import org.junit.Test; import redis.clients.jedis.Jed

  • Java操作Redis详细介绍

    1. 简介 Redis 是一个开源(BSD许可)的,内存中的key-value存储系统,它可以用作数据库.缓存和消息中间件. 2. 对key的操作 首先要建立连接Jedis jedis = new Jedis("127.0.0.1", 6379),然后就可以对string,set,zset,hash进行操作了. //对key的测试 public void keyTest() { System.out.println(jedis.flushDB()); //清空数据 System.out

  • 基于Java代码操作Redis过程详解

    Jedis简介 实际开发中,我们需要用Redis的连接工具连接Redis然后操作Redis, 对于主流语言,Redis都提供了对应的客户端: 提供了很多客户端 官方推荐的是Jedis 托管地址:https://github.com/xetorthio/jedis 要使用redis首先得下载pom依赖 <dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId&g

  • Java使用Lettuce客户端在Redis在主从复制模式下命令执行的操作

    1 redis主从复制的概念 多机环境下,一个redis服务接收写命令,当自身数据与状态发生变化,将其复制到一个或多个redis.这种模式称为主从复制.在redis中通过命令salveof命令让执行该命令的redis复制另一个redis数据与状态.我们将主服务器称为master,从服务器称为slave. 主从复制保证了网络异常正常时,网络断开重的情况下将数据复制.网络正常时master会通过发送命令保持对slave更新,更新包括客户端的写入,key的过期或被逐出等网络异常,master与slav

  • Java使用RedisTemplate模糊删除key操作

    Redis模糊匹配批量删除操作,使用RedisTemplate操作: public void deleteByPrex(String prex) { Set<String> keys = redisTemplate.keys(prex); if (CollectionUtils.isNotEmpty(keys)) { redisTemplate.delete(keys); } } prex为迷糊匹配的key,如cache:user:* 这里需要判断keys是否存在,如果一个都匹配不到会报错:

  • java操作Redis缓存设置过期时间的方法

    关于Redis的概念和应用本文就不再详解了,说一下怎么在java应用中设置过期时间. 在应用中我们会需要使用redis设置过期时间,比如单点登录中我们需要随机生成一个token作为key,将用户的信息转为json串作为value保存在redis中,通常做法是: //生成token String token = UUID.randomUUID().toString(); //把用户信息写入redis jedisClient.set(REDIS_USER_SESSION_KEY + ":"

  • Redis有序集合类型的操作_动力节点Java学院整理

    今天我们说一下Redis中最后一个数据类型 "有序集合类型",回首之前学过的几个数据结构,不知道你会不会由衷感叹,开源的世界真好,写这些代码的好心人真的要一生平安哈,不管我们想没想的到的东西,在这个世界上都已经存在着,曾几何时,我们想把所有数据按照数据结构模式组成后灌输到内存中,然而为了达到内存共享的方式,不得不将这块内存单独部署,同时还要考虑怎么序列化,何时序列互的问题,烦心事太多太多...后来才知道有redis这么个玩意,能把高级的,低级的数据结构单独包装到一个共享内存中(Redi

  • 在Java中使用redisTemplate操作缓存的方法示例

    背景 在最近的项目中,有一个需求是对一个很大的数据库进行查询,数据量大概在几千万条.但同时对查询速度的要求也比较高. 这个数据库之前在没有使用Presto的情况下,使用的是Hive,使用Hive进行一个简单的查询,速度可能在几分钟.当然几分钟也并不完全是跑SQL的时间,这里面包含发请求,查询数据并且返回数据的时间的总和.但是即使这样,这样的速度明显不能满足交互式的查询需求. 我们的下一个解决方案就是Presto,在使用了Presto之后,查询速度降到了秒级.但是对于一个前端查询界面的交互式查询来

  • 使用java连接Redis,Maven管理操作

    pom配置 <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0

  • Java连接redis及基本操作示例

    本文实例讲述了Java连接redis及基本操作.分享给大家供大家参考,具体如下: 点击此处:本站下载安装. 解压安装 启动redis:使用cd命令切换目录到 D:\redis运行redis-server.exe redis.windows.conf 默认端口为6379 访问:切换到redis目录下运行 redis-cli.exe -h 127.0.0.1 -p 6379. pom.xml: <project xmlns="http://maven.apache.org/POM/4.0.0&

  • java Spring Boot 配置redis pom文件操作

    1.创建一个redis maven项目,在pom中添加如下信息 spring boot 版本 <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.0.4.RELEASE</version> </parent> 项目相关jar配置 &l

随机推荐