文档章节

Redis入门教程(三)— Java中操作Redis

dotleo
 dotleo
发布于 2017/08/29 11:32
字数 1806
阅读 50
收藏 0

精选30+云产品,助力企业轻松上云!>>>

在Redis的官网上,我们可以看到Redis的Java客户端众多

Redis客户端

其中,Jedis是Redis官方推荐,也是使用用户最多的Java客户端。

开始前的准备

创建项目

  1. 首先创建一个新的Java Project,命名为Jedis(你也可以给它你喜爱的名字)
  2. 在项目中新建一个Folder(文件夹),命名为“lib”
  3. 将jedis-2.1.0.jar、commons-pool-1.5.4.jar、junit-4.10.jar复制到lib文件夹下
  4. 选中文件夹或者三个jar文件,右击找到Build Path,选择菜单下的Add to Build Path加入到Build Path中

开始撸代码

继续之前,请务必阅读过Redis入门教程(二)—基本数据类型,这将对你有很大的帮助。


import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Set;

import org.junit.Before;
import org.junit.Test;

import redis.clients.jedis.BinaryClient.LIST_POSITION;
import redis.clients.jedis.Jedis;

/**
 * @author dotleo
 *
 */
public class Jedis_Test {
	
	//Java中操作Redis的对象
	private Jedis jedis ;
	
	@Before
	public void connection() {
		
		//连接Redis服务器,参数1为ip,参数2为端口号,请根据自己实际情况赋值
		jedis = new Jedis("192.168.1.233",6379);
	}
	
	/**
	 * redis字符串操作
	 */
	@Test
	public void stringTest() {
		
		//为避免多次运行Redis中存在键,导致结果不符合预期,每次执行时清理当前库
		//特别注意:在开发中请勿如此操作
		jedis.flushDB();
		
		//添加字符串
		jedis.set("age", "101");
		System.out.println("age = " + jedis.get("age"));
		//批量添加字符串
		jedis.mset("age1","1","age2","2");
		System.out.println("age1 = " + jedis.get("age1"));
		System.out.println("age2 = " + jedis.get("age2"));
		//添加字符串(仅在不存在时)
		jedis.setnx("price", "101");
		System.out.println("price = " + jedis.get("price"));
		//加1操作
		jedis.incr("price");
		System.out.println("price = " + jedis.get("price"));
		//拼接字符串
		jedis.append("age", "years");
		System.out.println("age = " + jedis.get("age"));
		//截取字符串
		String str = jedis.getrange("age", 0L, 5L);
		System.out.println("age[0,5] = " + str);
		//获取字符串长度
		Long len = jedis.strlen("age");
		System.out.println("age length = " + len);
		//删除字符串
		jedis.del("age");
		System.out.print("age = " + jedis.get("age"));
	}
	
	/**
	 * redis哈希操作
	 */
	@Test
	public void hashTest() {
		
		//为避免多次运行Redis中存在键,导致结果不符合预期,每次执行时清理当前库
		//特别注意:在开发中请勿如此操作
		jedis.flushDB();
		
		//添加值
		jedis.hset("student", "name", "zhangsan");
		//添加值(仅在不存在时)
		jedis.hsetnx("student", "age", "12");
		//批量添加值
		Map<String,String> map = new HashMap<String,String>();
		map.put("sex", "boy");
		map.put("address", "beijing");
		jedis.hmset("student", map);
		//获取值
		String str = jedis.hget("student", "name");
		System.out.println("student:name = " + str);
		//批量获取值
		List<String> list = jedis.hmget("student", "name","age");
		System.out.println("student:name = " + list.get(0));
		System.out.println("student:age = " + list.get(1));
		//获取key
		Set<String> set = jedis.hkeys("student");
		System.out.println("student keys:");
		for (String string : set) {
			System.out.println(string);
		}
		//获取值
		list = jedis.hvals("student");
		System.out.println("student vals:");
		for (String string : list) {
			System.out.println(string);
		}
		//获取key和值
		map = jedis.hgetAll("student");
		System.out.println("student keys vals:");
		for (String key:map.keySet()) {
			System.out.println(key + " = " + map.get(key));
		}
		//删除值
		jedis.hdel("student", "sex");
		System.out.println("student:sex = " + jedis.hget("student", "sex"));
		//获取长度
		Long len = jedis.hlen("student");
		System.out.println("student length = " + len);
	}
	
	/**
	 * redis列表操作
	 */
	@Test
	public void listTest() {
		
		//为避免多次运行Redis中存在键,导致结果不符合预期,每次执行时清理当前库
		//特别注意:在开发中请勿如此操作
		jedis.flushDB();
		
		//表头添加
		jedis.lpush("student", "xiaoli","xiaowang","xiaoliu","xiaozhang");
		//表尾添加
		jedis.rpush("student", "zhangsan","lisi","wangwu");
		//通过索引获取元素
		String str = jedis.lindex("student", 1L);
		System.out.println("student 1st = " + str);
		//在元素前或者后插入元素
		jedis.linsert("student", LIST_POSITION.BEFORE, "xiaozhang", "zhangsan");
		//从表头弹出
		str = jedis.lpop("student");
		System.out.println("student first = " + str);
		//从表尾弹出
		str = jedis.rpop("student");
		System.out.println("student end = " + str);
		//删除
		jedis.lrem("student", 2, "zhangsan");
		//获取所有值
		List<String> list = jedis.lrange("student", 0L, -1L);
		System.out.println("student vals:");
		for (String string : list) {
			System.out.println(string);
		}
	}
	
	/**
	 * redis集合操作
	 */
	@Test
	public void setTest() {

		//为避免多次运行Redis中存在键,导致结果不符合预期,每次执行时清理当前库
		//特别注意:在开发中请勿如此操作
		jedis.flushDB();
		
		//添加成员
		jedis.sadd("student", "zhangsan","lisi");
		jedis.sadd("monitor","wangwu","zhangsan");
		//获取成员数
		Long count = jedis.scard("student");
		System.out.println("student count = " + count);
		//获取成员
		Set<String> set = jedis.smembers("student");
		System.out.println("student members:");
		for (String string : set) {
			System.out.println(string);
		}
		//是否为该集合的成员
		boolean bool = jedis.sismember("student", "zhangsan");
		System.out.println("member zhangsan exist?\n" + bool);
		//交集
		set = jedis.sinter("student","monitor");
		System.out.println("student inter monitor members:");
		for (String string : set) {
			System.out.println(string);
		}
		//并集
		set = jedis.sunion("student","monitor");
		System.out.println("student union monitor members:");
		for (String string : set) {
			System.out.println(string);
		}
		//补集
		set = jedis.sdiff("student","monitor");
		System.out.println("student diff monitor members:");
		for (String string : set) {
			System.out.println(string);
		}
		//随机返回成员
		String str = jedis.srandmember("student");
		System.out.println("random member:\n" + str);
		//移动成员
		jedis.smove("student", "monitor", "lisi");
		//删除成员
		jedis.srem("monitor", "zhangsan");
		//显示
		set = jedis.smembers("student");
		System.out.println("student members:");
		for (String string : set) {
			System.out.println(string);
		}
		set = jedis.smembers("monitor");
		System.out.println("monitor members:");
		for (String string : set) {
			System.out.println(string);
		}
	}
	
	/**
	 * redis有序集合操作
	 */
	@Test
	public void sortSetTest() {

		//为避免多次运行Redis中存在键,导致结果不符合预期,每次执行时清理当前库
		//特别注意:在开发中请勿如此操作
		jedis.flushDB();
		
		//添加成员
		Map<Double,String> map = new HashMap<Double,String>();
		map.put(50d, "zhangsan");
		map.put(60d, "lisi");
		map.put(70d, "wangwu");
		map.put(80d, "zhaoliu");
		map.put(90d, "yangqi");
		map.put(120d, "xiaoming");
		map.put(130d, "xiaozhang");
		map.put(140d, "xiaoli");
		map.put(150d, "xiaoliu");
		jedis.zadd("score", map);
		//更新分数
		jedis.zadd("score", 100d, "zhangsan");
		//获取成员的分数值
		Double dou = jedis.zscore("score", "zhangsan");
		System.out.println("zhangsan score :\n" + dou);
		//按照成员分数小到大返回索引区间的成员
		Set<String> set = jedis.zrange("score", 0, -1);
		System.out.println("score member order:");
		for (String string : set) {
			System.out.println(string);
		}
		//按照成员分数大到小返回索引区间的成员
		set = jedis.zrevrange("score", 0, -1);
		System.out.println("score member reverse:");
		for (String string : set) {
			System.out.println(string);
		}
		//按照成员分数小到大返回分数值区间的成员
		set = jedis.zrangeByScore("score", 50d, 80d);
		System.out.println("score member order:");
		for (String string : set) {
			System.out.println(string);
		}
		//返回有序集合中指定成员的索引
		Long index = jedis.zrank("score", "xiaoliu");
		System.out.println("xiaoliu index is:\n" + index);
	}
}

如果你读过我的Redis入门教程(二)—基本数据类型,你会发现上面这些命令在其中都有提及,只是诸如参数传递的形式、返回值的类型等有少许不同,但方法名和文中的指令完全相同,其他方面也大同小异。因此在上面的代码中并没有像文章中一样尽可能多的列出所有的函数,还需你自己勤于练习、摸索。

Redis连接池


import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

/**
 * @author dotleo
 *
 */
public class RedisUtil {

	//Redis服务器ip地址
	private static final String IP_ADDRESS = "192.168.1.233";
	
	//Redis端口号
	private static final int PORT = 6379;
	
	//可用连接实例的最大数目,默认值为8;
	//如果赋值为-1,则表示不限制;如果pool已经分配了maxActive个jedis实例,则此时pool的状态为exhausted(耗尽)。
	private static final int MAX_ACTIVE = 1024;
	
	//控制一个pool最多有多少个状态为idle(空闲的)的jedis实例,默认值也是8。
	private static final int MAX_IDLE = 200;
	
	//等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时。如果超过等待时间,则直接抛出JedisConnectionException;
	private static final int MAX_WAIT = 10000;
	
	//在borrow一个jedis实例时,是否提前进行validate操作;如果为true,则得到的jedis实例均是可用的;  
    private static boolean TEST_ON_BORROW = true;
    
	//Jedis连接池对象
	private static JedisPool jedisPool = null;
	
	
	/**
	 * 初始化连接池
	 */
	static {
		try {
			JedisPoolConfig conf = new JedisPoolConfig();
			conf.setMaxActive(MAX_ACTIVE);
			conf.setMaxIdle(MAX_IDLE);
			conf.setMaxWait(MAX_WAIT);
			conf.setTestOnBorrow(TEST_ON_BORROW);
			jedisPool = new JedisPool(conf, IP_ADDRESS, PORT);
		} catch(Exception ex) {
			ex.printStackTrace();
		}
	}
	
	 /**
	 * 获取Jedis实例
	 * @return Jedis实例
	 */
	public synchronized static Jedis getJedis() {  
         try {  
             if (jedisPool != null) {  
                 Jedis resource = jedisPool.getResource();  
                 return resource;  
             } else {  
                 return null;  
             }  
         } catch (Exception e) {  
             e.printStackTrace();  
             return null;  
         }  
     }
	
	/** 
     * 释放jedis资源 
     * @param jedis Jedis对象 
     */  
     public static void returnResource(final Jedis jedis) {  
         if (jedis != null) {  
              jedisPool.returnResourceObject(jedis);  
         }  
     }  
}


文章除注明转载外,均为原创。欢迎任何形式的转载,但请务必注明出处:

文章转载自 OSchina 开源中国
本文作者:dotleo
作者主页:https://my.oschina.net/u/2930289/blog

dotleo
粉丝 17
博文 51
码字总数 52059
作品 0
天津
程序员
私信 提问
加载中
请先登录后再评论。
Redis入门(四)-Java操作Redis

系列文章的第四篇,这一节看一下如何用Java版本的redis客户端工具--来操作redis。 Jedis封装了丰富的api来对redis的五种数据类型 string 、hash 、list 、set 、zset进行操作,可以说命令行界...

osc_27xxmyzv
2019/12/06
24
0
Spring Data Redis

关注公众号:CoderBuff,回复“redis”获取《Redis5.x入门教程》完整版PDF。 《Redis5.x入门教程》目录 第一章 · 准备工作 第二章 · 数据类型 第三章 · 命令 第四章 · 配置 第五章 · Ja...

osc_43of92sp
02/27
2
0
Spring Data Redis

关注公众号:CoderBuff,回复“redis”获取《Redis5.x入门教程》完整版PDF。 《Redis5.x入门教程》目录 第一章 · 准备工作 第二章 · 数据类型 第三章 · 命令 第四章 · 配置 第五章 · Ja...

OKevin
02/27
0
0
Jedis客户端以及redis中的pipeline批量操作

关注公众号:CoderBuff,回复“redis”获取《Redis5.x入门教程》完整版PDF。 《Redis5.x入门教程》目录 第一章 · 准备工作 第二章 · 数据类型 第三章 · 命令 第四章 · 配置 第五章 · Ja...

osc_4qn62tcp
04/16
4
0
Jedis客户端以及redis中的pipeline批量操作

关注公众号:CoderBuff,回复“redis”获取《Redis5.x入门教程》完整版PDF。 《Redis5.x入门教程》目录 第一章 · 准备工作 第二章 · 数据类型 第三章 · 命令 第四章 · 配置 第五章 · Ja...

OKevin
02/24
0
0

没有更多内容

加载失败,请刷新页面

加载更多

跨越了6个阶段,我仍然是生物信息学初学者

首先非常欢迎大家分享自己与生物信息学/生信技能树的故事! 上一期是:我如何从生物科学到生物信息 这一期是我在朋友圈看到了我们单细胞天地常驻编辑周运来的真情流露,邀请他投稿的我们生信...

biotrainee
前天
0
0
网飞是如何运用心理学来完善其客户体验的

原文地址:https://36kr.com/p/5289228 译者:俊一 占据全球网站流量 15%的奈飞,其用户体验设计背后有哪些秘密? 神译局是 36 氪旗下编译团队,关注科技、商业、职场、生活等领域,重点介绍...

高行
02/08
0
0
shell编程中的循环脚本

本文中的部分脚本来源于网络,就不申明原创了,如果这些东西自己学会了,那就是属于自己的了。 求从1加到100的和 使用for循环求和: #!/bin/bash declare -i sum=0 for ((i=1;i<=100;i++));...

Double_冬
2018/08/16
0
0
智能合约:介绍、geth、Ethereum Wallet

从看雪论坛换了一本《智能合约安全分析和审计指南》,看了一些智能合约相关的内容,因为我之前对于区块链的了解仅仅是只知道世界上有一种叫做比特币的东西,所以对于这些概念的理解还是比较困...

yichen115
04/26
0
0
Vue和React技术风格上的不同

在主流框架中,Vue和React都属于全球热门,各自有着大量用户,两者之间的优缺点便带来了众多讨论。 那么这两者之间的关键区别在于哪些方面?为何熟练掌握Vue成为越来越多公司的岗位要求? Vu...

若川
07/02
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部