美文网首页
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