Redis【4】Java Jedis 操作 Redis

Jedis连接池工具类
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
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);
}
}

}
操作数据库
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
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));
}
}
JedisPool实现2
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
* 【简单使用】jedis连接池: JedisPool
1. 创建JedisPool连接池对象
2. 调用方法 getResource()方法获取Jedis连接
//0.创建一个配置对象
JedisPoolConfig config = new JedisPoolConfig();
config.setMaxTotal(50);
config.setMaxIdle(10);

//1.创建Jedis连接池对象
JedisPool jedisPool = new JedisPool(config,"localhost",6379);

//2.获取连接
Jedis jedis = jedisPool.getResource();
//3. 使用
jedis.set("hehe","heihei");


//4. 关闭 归还到连接池中
jedis.close();

* 【进行优化】连接池工具类
public class JedisPoolUtils {

private static JedisPool jedisPool;

static{
//读取配置文件
InputStream is = JedisPoolUtils.class.getClassLoader().getResourceAsStream("jedis.properties");

/*
jedis.properties:四行内容

host=127.0.0.1
port=6379
maxTotal=50
maxIdle=10
*/

//创建Properties对象
Properties pro = new Properties();
//关联文件
try {
pro.load(is);
} catch (IOException e) {
e.printStackTrace();
}
//获取数据,设置到JedisPoolConfig中
JedisPoolConfig config = new JedisPoolConfig();
config.setMaxTotal(Integer.parseInt(pro.getProperty("maxTotal")));
config.setMaxIdle(Integer.parseInt(pro.getProperty("maxIdle")));

//初始化JedisPool
jedisPool = new JedisPool(config,pro.getProperty("host"),Integer.parseInt(pro.getProperty("port")));

}


/**
* 获取连接方法
*/
public static Jedis getJedis(){
return jedisPool.getResource();
}
}