package redis.redis; import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool; /** * 描述:Jedis连接池 工具 类 * 【时间 2019-05-20 15:13:34 作者 陶攀峰】 */ public class JedisPoolUtil { private static volatile JedisPool jedisPool=null; private JedisPoolUtil() {} /** * 描述:获取 * 【时间 2019-05-21 11:02:24 作者 陶攀峰】 */ public static JedisPool getJeidPoolInstance() { if (jedisPool==null) { synchronized (JedisPoolUtil.class) { if (jedisPool==null) { jedisPool=new JedisPool("192.168.37.160",6379); } } } return jedisPool; } /** * 描述:关闭 * 【时间 2019-05-21 11:02:13 作者 陶攀峰】 */ public static void close(JedisPool jedisPool,Jedis jedis) { if (jedis!=null) { jedisPool.returnResourceObject(jedis); } } } 描述:Jedis连接池工具类
package redis.redis; import redis.clients.jedis.BinaryClient.LIST_POSITION; import java.util.HashMap; import java.util.Map; import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool; import redis.clients.jedis.Transaction; /** * 描述:操作数据库 * 【时间 2019-05-20 15:28:46 作者 陶攀峰】 */ public class Redis_Test { public static void main(String[] args) { JedisPool jedisPool=JedisPoolUtil.getJeidPoolInstance(); Jedis jedis=null; try { jedis=jedisPool.getResource();//获取 System.out.println("连接:"+jedis.ping());//测试连接性 正常返回PONG transaction(jedis);//事务 basics(jedis);//基础操作 } catch (Exception e) { e.printStackTrace(); }finally {//关闭 JedisPoolUtil.close(jedisPool, jedis); } } /** * 描述:Redis事务 * 【时间 2019-05-20 15:33:59 作者 陶攀峰】 */ public static void transaction(Jedis jedis){ int k3=10; jedis.watch("k1"); //Thread.sleep(7000); if (Integer.parseInt(jedis.get("k1"))<k3) { jedis.unwatch(); System.out.println("---modify---"); }else { Transaction transaction=jedis.multi(); transaction.decrBy("k1", k3); transaction.incrBy("k2", k3); transaction.exec(); System.out.println("---"+jedis.get("k1")+"---"+jedis.get("k2")); } } /** * 描述:Redis基础 * 【时间 2019-05-21 08:07:33 作者 陶攀峰】 */ public static void basics(Jedis jedis) { jedis.set("k1", "v1"); jedis.set("k2", "v2"); System.out.println("当前数据库记录:"+jedis.dbSize()); System.out.println("jedis.keys(\"*\"):"+jedis.keys("*"));//获取所有key jedis.select(1);//切换数据库 下标从0开始 到 15 ,共16个数据库 System.out.println(jedis.keys("*")); System.out.println(jedis.dbSize());//当前库的数据大小 key的数量 System.out.println(jedis.randomKey());//随机出一个key jedis.flushDB();//清空当前数据库 jedis.flushAll();//清空全部数据库 //-------------------String-------------------- jedis.set("k1", "v1"); System.out.println(jedis.get("k1")); jedis.del("k1"); jedis.append("k1", "556677");//追加 System.out.println(jedis.get("k1")); System.out.println(jedis.strlen("k1"));//得到长度 jedis.set("k2", "2"); jedis.incr("k2");//增加1 jedis.decr("k2");//减少1 jedis.incrBy("k2", 5);//增加5 jedis.decrBy("k2", 20);//减少20 System.out.println(jedis.get("k2")); jedis.flushAll();//清空全部数据库 jedis.set("k3", "tpf951101"); System.out.println(jedis.getrange("k3", 2, 3));//从0开始包括2和3 System.out.println(jedis.setrange("k3", 2, "pf"));//从下标2开始 包括2 开始替换两个字符pf System.out.println(jedis.get("k3")); jedis.setex("k3", 10, "v3");//10为过期时间 单位秒 System.out.println(jedis.get("k3")); System.out.println(jedis.ttl("k3"));//返回还有多少秒到期,到期自动删除,-2已过期 jedis.setnx("k4", "v4");//不存在k4才能设值成功 System.out.println(jedis.get("k4")); jedis.flushAll(); jedis.mset("k1","v11","k2","v22"); System.out.println(jedis.mget("k1","k2")); System.out.println(jedis.keys("*")); jedis.set("k5", "v5"); jedis.del("k5"); jedis.msetnx("k4","v44","k5","v55");//全部不存在才能成功 System.out.println(jedis.mget("k4","k5")); System.out.println(jedis.getSet("k1", "19951101"));//先返回设值前内容再设值 //-------------------List-------------------- jedis.lpush("l1", "1","2","3","4","5"); jedis.rpush("l2", "11","22","33","44","55"); System.out.println(jedis.lrange("l1", 0, -1));//0 -1 查询全部 System.out.println(jedis.lrange("l2", 0, -1)); System.out.println(jedis.lpop("l1"));//删除表头、返回删除的内容 System.out.println(jedis.lpop("l2")); System.out.println(jedis.rpop("l1"));//删除表尾、返回删除的内容 System.out.println(jedis.rpop("l2")); System.out.println(jedis.lindex("l1", 1));//返回下标1的内容 System.out.println(jedis.llen("l1"));//相当于list.size() jedis.ltrim("l1", 2, 3);//截取2-3 包括2和3替换之前的内容 System.out.println(jedis.lrem("l1", 1, "33"));;//第一个为key 第二个为1 第三个为要删除的value 返回删除的条数 jedis.rpoplpush("l1", "l2");//把l1的尾添加到l2的头 jedis.lset("l2", 0, "333");//把下标为0的值 改为333 jedis.linsert("l2", LIST_POSITION.BEFORE, "3", "a3"); jedis.linsert("l2", LIST_POSITION.AFTER, "4", "a4"); System.out.println(jedis.lrange("l1", 0, -1)); System.out.println(jedis.lrange("l2", 0, -1)); //-------------------Set-------------------- jedis.sadd("s1", "1","2","3","4","5"); System.out.println(jedis.sismember("s1", "6"));//s1中是否存在6 存在true 不存在false System.out.println(jedis.scard("s1"));//相当于list.size() System.out.println(jedis.srem("s1", "5"));//删除s1中的5 成功返回1 失败返回0 System.out.println(jedis.srandmember("s1"));//随机出一条记录 System.out.println(jedis.srandmember("s1",3));//随机出三条记录 System.out.println(jedis.srandmember("s1",9));//如果大于等于记录数 就等于查询全部 System.out.println(jedis.spop("s1"));//随机删除一条数据 System.out.println(jedis.smove("s1", "s2", "3"));//把s1中的3移到s2的头 System.out.println(jedis.sdiff("s1","s2"));//s1有 s2没有 System.out.println(jedis.sinter("s1","s2"));//s1 s2 都有 System.out.println(jedis.sunion("s1","s2"));//s1 s2合集 System.out.println(jedis.smembers("s1")); //-------------------Hash-------------------- jedis.hset("stu", "id", "7"); System.out.println(jedis.hget("stu", "id")); Map<String, String> map=new HashMap<>(); map.put("id","13"); map.put("name", "daniu"); map.put("sex", "nan"); jedis.hmset("stu", map); System.out.println(jedis.hmget("stu", "id","name","sex")); System.out.println(jedis.hgetAll("stu")); System.out.println(jedis.hdel("stu", "id","sex2"));//返回删除的数量 System.out.println(jedis.hlen("stu")); System.out.println(jedis.hexists("stu", "name"));//存在true 不存在false System.out.println(jedis.hkeys("stu")); System.out.println(jedis.hvals("stu")); System.out.println(jedis.hincrBy("stu", "id", 2));//每次增加2 返回增加后的数值 System.out.println(jedis.hincrByFloat("stu", "id", 3.4));//每次增加3.4 返回增加后的数值 System.out.println(jedis.hsetnx("stu", "id1", "99"));//插入成功返回1 失败返回0 //-------------------Zset-------------------- jedis.zadd("zs1", 60, "v1"); jedis.zadd("zs1", 70, "v2"); jedis.zadd("zs1", 80, "v3"); jedis.zadd("zs1", 90, "v4"); jedis.zadd("zs1", 100, "v5"); System.out.println(jedis.zrange("zs1", 0, -1)); System.out.println(jedis.zrangeByScore("zs1", 60, 90));//60<=score<=90的value值 System.out.println(jedis.zrem("zs1", "v5","v6"));//返回删除记录数 System.out.println(jedis.zcard("zs1"));//返回数量 System.out.println(jedis.zcount("zs1", 60, 80));//60<=score<=80的数量 System.out.println(jedis.zrank("zs1", "v4"));//返回所在位置下标 System.out.println(jedis.zscore("zs1", "v1"));//返回v1的score //zre表示把原本的数据逆转顺序之后,再读取,不改变原有数据 System.out.println(jedis.zrevrank("zs1", "v4")); System.out.println(jedis.zrevrange("zs1", 0, -1)); } } 描述:操作数据库
以上所述就是小编给大家介绍的《Redis【4】Java Jedis 操作 Redis~》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- JavaScript骚操作之操作符
- Go 语言操作 MySQL 之 事务操作
- C# 数据操作系列 - 1. SQL基础操作
- Vim 跨行操作与 Ex 命令操作范围
- 并发环境下,先操作数据库还是先操作缓存?
- 关于HBase Shell基本操作的表操作示例
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。