使用Jedis进行Redis的基本的操作

在使用Jedis连接Redis进行操作之前,我们先在服务器上使用Redis自带的客户端进行操作

# ./redis-cli -h 127.0.0.1 -p 6379

进入操作页面,因为我这里设置了密码,所以要先使用『auth』命令来进行密码验证:

127.0.0.1:6379> auth 你的密码

出现『ok』则表示验证通过。


首先我们来了解一下redis中的数据类型,从官网上我们可以了解到Redis的数据类型:
https://redis.io/topics/data-types

Strings
Lists
Sets
Hashes
Sorted sets

我们最长使用的是String类型,hashes类型,偶尔也会用到Lists的类型。所有的命令都可以在官网中看到
https://redis.io/commands#string 这个连接中的是string类型的操作命令。
https://redis.io/commands#hash 这个连接中的hash类型的操作命令。
https://redis.io/commands#list 这个连接中的list类型的操作命令。
这里以list的类型的用法为例:list的类型本质上就是一个数组,需要将数据push其中。

redis> RPUSH mylist "one"
(integer) 1
redis> RPUSH mylist "two"
(integer) 2
redis> RPUSH mylist "three"
(integer) 3
redis> LSET mylist 0 "four"
"OK"
redis> LSET mylist -2 "five"
"OK"
redis> LRANGE mylist 0 -1
1) "four"
2) "five"
3) "three"
redis> 

命令行的示例显示完毕。


简单测试

接下来我们使用Jedis来操作Redis,Jedis是用Java语言开发的可操作Redis的第三方库。这里建议大家可以直接看Github里的例子来进行操作,这里先实现一个最简单的例子:
https://github.com/xetorthio/jedis

Jedis jedis = new Jedis("localhost");
jedis.auth("你的密码");
jedis.dbSize();

自己使用的代码

以上代码来自 Jedis项目中的JedisTest.java的文件,下面是我自己的测试的代码:

//创建Redis的连接,这里是ip是:127.0.0.1,端口用默认的6379,
Jedis jedis = new Jedis("127.0.0.1",6379);
jedis.auth("你的密码");
System.out.println(jedis.dbSize());
jedis.set("test", "123456789")
System.out.println(jedis.get("test"));
jedis.close();

上面的例是自己测试的。因为每次的操作都有连接Redis和关闭操作,可以把他们都放到一个方法里面,真正需要改版的参数的是key和value。当然这里推荐使用连接池的进行操作。

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import stock.utils.LoadProperties;

/**
 * Created by jamesmarva on 24/08/2018.
 */
public class JedisClientPool implements JedisClient {

    JedisPool jedisPool = new JedisPool("127.0.0.1", "6379");

    public String set(String key, String value) {
        Jedis jedis = jedisPool.getResource();
        jedis.auth("你的密码");
        String result = jedis.set(key, value);
        jedis.close();
        return result;
    }

    public String get(String key) {
        Jedis jedis = jedisPool.getResource();
        jedis.auth("你的密码");
        String result = jedis.get(key);
        jedis.close();
        return result;
    }

    public Boolean exists(String key) {
        Jedis jedis = jedisPool.getResource();
        jedis.auth("你的密码");
        Boolean result = jedis.exists(key);
        jedis.close();
        return result;
    }

    public Long expire(String key, int seconds) {
        Jedis jedis = jedisPool.getResource();
        jedis.auth("你的密码");
        Long result = jedis.expire(key, seconds);
        jedis.close();
        return result;
    }

    public Long ttl(String key) {
        Jedis jedis = jedisPool.getResource();
        jedis.auth("你的密码");
        Long result = jedis.ttl(key);
        jedis.close();
        return result;
    }

    public Long incr(String key) {
        Jedis jedis = jedisPool.getResource();
        jedis.auth("你的密码");
        Long result = jedis.incr(key);
        jedis.close();
        return result;
    }

    public Long hset(String key, String field, String value) {
        Jedis jedis = jedisPool.getResource();
        jedis.auth("你的密码");
        Long result = jedis.hset(key, field, value);
        jedis.close();
        return result;
    }

    public String hget(String key, String field) {
        Jedis jedis = jedisPool.getResource();
        jedis.auth("你的密码");
        String result = jedis.hget(key, field);
        jedis.close();
        return result;
    }

    public Long hdel(String key, String... field) {
        Jedis jedis = jedisPool.getResource();
        jedis.auth("你的密码");
        Long result = jedis.hdel(key, field);
        jedis.close();
        return result;
    }
}

如果没有设置密码,就不用auth这个方法。

猜你喜欢

转载自blog.csdn.net/RAYFUXK/article/details/82110378