美文网首页
Java使用Redis实例

Java使用Redis实例

作者: crazybaby94 | 来源:发表于2020-10-26 11:18 被阅读0次

转载自:https://www.cnblogs.com/zchloverh/p/11690673.html

在开始在 Java 中使用 Redis 前, 我们需要确保已经安装了 redis 服务及 Java redis 驱动,且你的机器上能正常使用 Java。

1)redis安装步骤参考

2)需要下载jedis.jar驱动包

redis安装包与jedis.jar提取链接:https://pan.baidu.com/s/1Y2jSlGMsuydbTqJZr_RJqg     提取码:k9pj 

 

一:新建一个JAVAWEB项目

 点击finish即可,web.xml不重要

再将jedis.jar架包放入WEB-INF下的lib中

 二:实践案例

1. 连接本地的 Redis 服务和查看服务是否运行 

  1)首先打开redis服务

    2)创建RedisJava类

publicclass RedisJava {

    publicstaticvoid main(String[] args) {

        // 连接本地的 Redis 服务Jedis jedis =newJedis("localhost");

        System.out.println("连接本地的 Redis 服务成功!");

        // 查看服务是否运行System.out.println("服务 正在运行: " + jedis.ping());

    }

}

  运行结果:

  需要用到redis时我们需要开启redis服务

2.Redis Java String(字符串) 实例 

publicstaticvoid main(String[] args) {

        // 连接本地的 Redis 服务Jedis jedis =newJedis("localhost");

        System.out.println("连接本地的 Redis 服务成功!");

        // 设置 redis 字符串数据jedis.set("souvc", "http://www.cnblogs.com/liuhongfeng/");

        // 获取存储的数据并输出System.out.println("redis存储的字符串是: " + jedis.get("souvc"));

    }

  输出结果:

3.Redis Java List(列表) 实例 (1)

publicstaticvoid main(String[] args) {

        // 连接本地的 Redis 服务Jedis jedis =newJedis("localhost");

        System.out.println("连接本地的 Redis 服务成功!");

        // 存储数据到列表中jedis.lpush("kecheng", "java");

        jedis.lpush("kecheng", "php");

        jedis.lpush("kecheng", "Mysql");

        // 获取存储的数据并输出List list = jedis.lrange("kecheng", 0, 5);

        for(inti = 0; i < list.size(); i++) {

            System.out.println("redis list里面存储的值是:" + list.get(i));

        }

    }

  输出结果:

Redis Java List(列表) 实例 (2)

publicstaticvoid main(String[] args) {

        // 连接本地的 Redis 服务Jedis jedis =newJedis("localhost");

        System.out.println("连接本地的 Redis 服务成功!");

        //开始前,先移除所有的内容  jedis.del("java framework"); 

        System.out.println(jedis.lrange("java framework",0,-1)); 

        //先向key java framework中存放三条数据  jedis.lpush("java framework","spring"); 

        jedis.lpush("java framework","struts"); 

        jedis.lpush("java framework","hibernate");

        //再取出所有数据jedis.lrange是按范围取出, 

        // 第一个是key,第二个是起始位置,第三个是结束位置,jedis.llen获取长度 -1表示取得所有  System.out.println(jedis.lrange("java framework",0,-1)); 

        jedis.del("java framework");

        jedis.rpush("java framework","spring"); 

        jedis.rpush("java framework","struts"); 

        jedis.rpush("java framework","hibernate");

        System.out.println(jedis.lrange("java framework",0,-1));

    }

  输出结果:

住:若开始前未移除所有内容jedis.del("java framework");  结果执行一次将会多一条数据,一下是执行三次之后的结果

 4. Redis Java Map 实例

publicstaticvoid main(String[] args) {

        // 连接本地的 Redis 服务Jedis jedis =newJedis("localhost");

        System.out.println("连接本地的 Redis 服务成功!");

        //-----添加数据----------  Map map =newHashMap();

        map.put("name", "xinxin");

        map.put("age", "22");

        map.put("qq", "123456");

        jedis.hmset("user",map);

        //取出user中的name,执行结果:[minxr]-->注意结果是一个泛型的List 

        //第一个参数是存入redis中map对象的key,后面跟的是放入map中的对象的key,后面的key可以跟多个,是可变参数  List rsmap = jedis.hmget("user", "name", "age", "qq");

        System.out.println(rsmap); 

        //删除map中的某个键值  jedis.hdel("user","age");

        System.out.println(jedis.hmget("user", "age"));//因为删除了,所以返回的是null  System.out.println(jedis.hlen("user"));//返回key为user的键中存放的值的个数2 System.out.println(jedis.exists("user"));//是否存在key为user的记录 返回true  System.out.println(jedis.hkeys("user"));//返回map对象中的所有key  System.out.println(jedis.hvals("user"));//返回map对象中的所有value 

        Iterator iter=jedis.hkeys("user").iterator(); 

        while (iter.hasNext()){ 

            String key = iter.next(); 

            System.out.println(key+":"+jedis.hmget("user",key)); 

        } 

    }

  输出结果:

 5. Redis Java Set 实例

// 连接本地的 Redis 服务Jedis jedis =newJedis("localhost");

        System.out.println("连接本地的 Redis 服务成功!");//添加  jedis.sadd("users","liuling"); 

        jedis.sadd("users","xinxin"); 

        jedis.sadd("users","ling"); 

        jedis.sadd("users","zhangxinxin");

        jedis.sadd("users","who"); 

        //移除noname  jedis.srem("users","who"); 

        System.out.println(jedis.smembers("users"));//获取所有加入的value  System.out.println(jedis.sismember("users", "who"));//判断 who 是否是user集合的元素  System.out.println(jedis.srandmember("users")); 

        System.out.println(jedis.scard("users"));//返回集合的元素个数         

    }

  输出结果:

5. Redis Java Sort实例

publicstaticvoid main(String[] args) {

        // 连接本地的 Redis 服务Jedis jedis =newJedis("localhost");

        System.out.println("连接本地的 Redis 服务成功!");

        //jedis 排序 

        //注意,此处的rpush和lpush是List的操作。是一个双向链表(但从表现来看的)  jedis.del("a");//先清除数据,再加入数据进行测试  jedis.rpush("a", "1"); 

        jedis.lpush("a","6"); 

        jedis.lpush("a","3"); 

        jedis.lpush("a","9"); 

        System.out.println(jedis.lrange("a",0,-1));// [9, 3, 6, 1]  System.out.println(jedis.sort("a"));//[1, 3, 6, 9]  //输入排序后结果  System.out.println(jedis.lrange("a",0,-1)); 

    }

  输出结果:

注意:如果是出现这个错误,那么是因为设置了密码。

我们需要加上一个auth方法进行校验。

// 连接本地的 Redis 服务

Jedis jedis = new Jedis("localhost");

//jedis.auth("souvc");

System.out.println("连接本地的 Redis 服务成功!");

相关文章

网友评论

      本文标题:Java使用Redis实例

      本文链接:https://www.haomeiwen.com/subject/nllamktx.html