当前位置 博文首页 > F_xiao_chou的博客:非关系数据库之Redis ----七、Redis官方推荐

    F_xiao_chou的博客:非关系数据库之Redis ----七、Redis官方推荐

    作者:[db:作者] 时间:2021-09-15 16:33

    Jedis是Redis官方推出的一款面向Java的客户端,提供了很多接口供Java语言调用。可以在Redis官网下载,当然还有一些开源爱好者提供的客户端,如Jredis、SRP等等,推荐使用Jedis。

    Jdeis的基本使用

    //连接redis ,redis的默认端口是6379

    Jedis jedis = new?Jedis ("localhost",6379);

    //验证密码,如果没有设置密码这段代码省略

    jedis.auth("password");

    jedis.connect();//连接?

    jedis.disconnect();//断开连接

    ?Set<String> keys = jedis.keys("*"); //列出所有的key?

    Set<String> keys = jedis.keys("key"); //查找特定的key

    //移除给定的一个或多个key,如果key不存在,则忽略该命令.

    jedis.del("key1");

    jedis.del("key1","key2","key3","key4","key5");

    //移除给定key的生存时间(设置这个key永不过期)?

    jedis.persist("key1");

    //检查给定key是否存在?

    jedis.exists("key1");

    //将key改名为newkey,当key和newkey相同或者key不存在时,返回一个错误?

    jedis.rename("key1", "key2");

    //返回key所储存的值的类型。

    //none(key不存在),string(字符串),list(列表),set(集合),zset(有序集),hash(哈希表)

    ?jedis.type("key1");

    //设置key生存时间,当key过期时,它会被自动删除。

    jedis.expire("key1", 5);//5秒过期

    //字符串值value关联到key。

    jedis.set("key1", "value1");

    ?//将值value关联到key,并将key的生存时间设为seconds(秒)。

    ?jedis.setex("foo", 5, "haha");

    ?//清空所有的key

    ?jedis.flushAll();

    //返回key的个数

    jedis.dbSize();

    //哈希表key中的域field的值设为value。

    jedis.hset("key1", "field1", "field1-value");

    jedis.hset("key1", "field2", "field2-value");

    Map map = new?HashMap();

    map.put("field1", "field1-value");

    map.put("field2", "field2-value");

    jedis.hmset("key1", map);

    //返回哈希表key中给定域field的值

    ?jedis.hget("key1", "field1");

    //返回哈希表key中给定域field的值(多个)?

    List list = jedis.hmget("key1","field1","field2");

    ?for(int?i=0;i<list.size();i++){ System.out.println(list.get(i)); }

    //返回哈希表key中所有域和值

    ?Map<String,String> map = jedis.hgetAll("key1");

    ?for(Map.Entry entry: map.entrySet()) { System.out.print(entry.getKey() + ":" + entry.getValue() + "\t"); }

    ?//删除哈希表key中的一个或多个指定域?

    jedis.hdel("key1", "field1");

    jedis.hdel("key1", "field1","field2");

    ?//查看哈希表key中,给定域field是否存在。

    jedis.hexists("key1", "field1");

    ?//返回哈希表key中的所有域?

    jedis.hkeys("key1");

    ?//返回哈希表key中的所有值?

    jedis.hvals("key1");

    //将值value插入到列表key的表头。

    jedis.lpush("key1", "value1-0");

    ?jedis.lpush("key1", "value1-1");

    jedis.lpush("key1", "value1-2");

    //返回列表key中指定区间内的元素,区间以偏移量start和stop指定.

    ?//下标(index)参数start和stop从0开始;

    //负数下标代表从后开始(-1表示列表的最后一个元素,-2表示列表的倒数第二个元素,以此类推)?

    List list = jedis.lrange("key1", 0, -1);//stop下标也在取值范围内(闭区间)?

    for(int?i=0;i<list.size();i++){ System.out.println(list.get(i)); }

    //返回列表key的长度。

    jedis.llen("key1")

    ?//将member元素加入到集合key当中。

    jedis.sadd("key1", "value0");

    ?jedis.sadd("key1", "value1");

    ?//移除集合中的member元素。

    jedis.srem("key1", "value1");

    //返回集合key中的所有成员。

    Set set = jedis.smembers("key1");

    //判断元素是否是集合key的成员?

    jedis.sismember("key1", "value2"));

    //返回集合key的元素的数量?

    jedis.scard("key1");

    //返回一个集合的全部成员,该集合是所有给定集合的交集?

    jedis.sinter("key1","key2")

    //返回一个集合的全部成员,该集合是所有给定集合的并集?

    jedis.sunion("key1","key2")

    //返回一个集合的全部成员,该集合是所有给定集合的差集?

    jedis.sdiff("key1","key2");

    spring-boot-starter-data-redis

    Spring-data-redis是spring大家族的一部分,提供了在srping应用中通过简单的配置访问redis服务,对reids底层开发包(Jedis, ?JRedis, and RJC)进行了高度封装,RedisTemplate提供了redis各种操作、异常处理及序列化,支持发布订阅,并对spring 3.1 cache进行了实现。

    spring-data-redis针对jedis提供了如下功能:
    1.连接池自动管理,提供了一个高度封装的“RedisTemplate”类
    2.针对jedis客户端中大量api进行了归类封装,将同一类型操作封装为operation接口
    ValueOperations:简单K-V操作
    SetOperations:set类型数据操作
    ZSetOperations:zset类型数据操作
    HashOperations:针对map类型的数据操作
    ListOperations:针对list类型的数据操作

    cs