Jedis——Hash/List/Set
Posted chenss15060100790
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Jedis——Hash/List/Set相关的知识,希望对你有一定的参考价值。
照着文档,找对应的函数就好了,封装得很完整,使用真不是什么难事。
至于二次封装的话,去实现Spring的Cache接口是一种方式,但是,不能把注解设计得太复杂,不爱用的话设计就失败了,需要牺牲一部分Jedis的特性,
个人推荐使用静态类,方便后期函数扩展,最大程度保证原有的功能。
Hash
package cn.swsk.xbry.api.v1.md1001; import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool; import redis.clients.jedis.JedisPoolConfig; import java.util.HashMap; import java.util.Map; /** * @author css * @date 2019/9/24 22:20 */ public class Test { public static void main(String[] args) throws InterruptedException { JedisPoolConfig config = new JedisPoolConfig(); config.setMaxTotal(25); config.setMaxIdle(20); config.setMinIdle(5); try ( JedisPool pool = new JedisPool(config, "127.0.0.1", 6379); Jedis jedis = pool.getResource()) { jedis.select(0); //type of hash //1、分别给哈希表key中的域设置值,分别对key中的字段1、字段2设置值 jedis.hset("testHash" , "field1" , "value1"); jedis.hset("testHash" , "field2" , "value1"); //2、用一个JAVA中的HashMap直接存储为redis中的哈希表 Map<String, String> map = new HashMap<>(); map.put("field11" , "value11"); map.put("field12" , "value11"); jedis.hmset("testHash2" , map); System.out.println(jedis.keys("*")); System.out.println(jedis.hkeys("testHash")); System.out.println(jedis.hgetAll("testHash")); System.out.println(jedis.hgetAll("testHash2")); } } }
List
package cn.swsk.xbry.api.v1.md1001; import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool; import redis.clients.jedis.JedisPoolConfig; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.Set; /** * @author css * @date 2019/9/24 22:20 */ public class Test { public static void main(String[] args) throws InterruptedException { JedisPoolConfig config = new JedisPoolConfig(); config.setMaxTotal(25); config.setMaxIdle(20); config.setMinIdle(5); try ( JedisPool pool = new JedisPool(config, "127.0.0.1", 6379); Jedis jedis = pool.getResource()) { jedis.select(0); //type of list String key1 = "key1"; //将值value插入到列表key的表头。 jedis.lpush(key1, "what", "how", "1", "0哈哈哈哈"); //取出 System.out.println(jedis.lpop(key1)); System.out.println(jedis.lpop(key1)); System.out.println(jedis.lpop(key1)); //返回列表key中指定区间内的元素,区间以偏移量start和stop指定. 下标(index)参数start和stop从0开始;
//负数下标代表从后开始(-1表示列表的最后一个元素,-2表示列表的倒数第二个元素,以此类推) 返回一个List System.out.println(jedis.lrange(key1, 0, jedis.llen(key1) - 1)); System.out.println(jedis.lrange(key1, 0, jedis.llen(key1) - 1)); } } }
Set
package cn.swsk.xbry.api.v1.md1001; import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool; import redis.clients.jedis.JedisPoolConfig; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.Set; /** * @author css * @date 2019/9/24 22:20 */ public class Test { public static void main(String[] args) throws InterruptedException { JedisPoolConfig config = new JedisPoolConfig(); config.setMaxTotal(25); config.setMaxIdle(20); config.setMinIdle(5); try ( JedisPool pool = new JedisPool(config, "127.0.0.1", 6379); Jedis jedis = pool.getResource()) { jedis.select(0); //type of set String key1 = "key3", key2 = "key2"; //将member元素加入到集合key当中。 jedis.sadd(key1, "I", "want", "to", "do", "something", "it", "with", "my", "friend"); //返回集合key的元素的数量 System.out.println(jedis.scard(key1)); //移除集合中的多个member元素。 jedis.srem(key1, "it"); System.out.println(jedis.scard(key1)); //判断元素是否是集合key的成员 System.out.println(jedis.sismember(key1, "it")); //返回集合key中的所有成员。返回一个set System.out.println(jedis.smembers(key1)); //交集 System.out.println(jedis.sinter(key1, key2)); //并集 System.out.println(jedis.sunion(key1, key2)); //差集 System.out.println(jedis.sdiff(key1, key2)); } } }
以上是关于Jedis——Hash/List/Set的主要内容,如果未能解决你的问题,请参考以下文章
Spring Boot + Redis 实现各种操作 #yyds干货盘点#
SpringBoot 操作 Redis的各种实现(以及JedisRedissonLettuce的区别比较)
SpringBoot 操作 Redis的各种实现(以及JedisRedissonLettuce的区别比较)