Java使用Redis实例
在开始在 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类 public class RedisJava { public static void main(String[] args) { // 连接本地的 Redis 服务 Jedis jedis = new Jedis("localhost"); System.out.println("连接本地的 Redis 服务成功!"); // 查看服务是否运行 System.out.println("服务 正在运行: " + jedis.ping()); } } 运行结果: 需要用到redis时我们需要开启redis服务 ? 2.Redis Java String(字符串) 实例? public static void main(String[] args) { // 连接本地的 Redis 服务 Jedis jedis = new Jedis("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) public static void main(String[] args) { // 连接本地的 Redis 服务 Jedis jedis = new Jedis("localhost"); System.out.println("连接本地的 Redis 服务成功!"); // 存储数据到列表中 jedis.lpush("kecheng","java"); jedis.lpush("kecheng","php"); jedis.lpush("kecheng","Mysql"); // 获取存储的数据并输出 List<String> list = jedis.lrange("kecheng",5); for (int i = 0; i < list.size(); i++) { System.out.println("redis list里面存储的值是:" + list.get(i)); } } 输出结果: ? ? ? Redis Java List(列表) 实例 (2) public static void main(String[] args) { // 连接本地的 Redis 服务 Jedis jedis = new Jedis("localhost"); System.out.println("连接本地的 Redis 服务成功!"); //开始前,先移除所有的内容 jedis.del("java framework"); System.out.println(jedis.lrange("java framework",-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",-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",-1)); } 输出结果: ? ? ? 住:若开始前未移除所有内容?jedis.del("java framework");? 结果执行一次将会多一条数据,一下是执行三次之后的结果 ? ? ? ?4.?Redis Java Map 实例 public static void main(String[] args) { // 连接本地的 Redis 服务 Jedis jedis = new Jedis("localhost"); System.out.println("连接本地的 Redis 服务成功!"); //-----添加数据---------- Map<String,String> map = new HashMap<String,String>(); 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<String> 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<String> 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 = new Jedis("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实例 ? ? public static void main(String[] args) { // 连接本地的 Redis 服务 Jedis jedis = new Jedis("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",-1));// [9,3,6,1] System.out.println(jedis.sort("a")); //[1,9] //输入排序后结果 System.out.println(jedis.lrange("a",-1)); } 输出结果: ? ? 注意:如果是出现这个错误,那么是因为设置了密码。 ? ? ? 我们需要加上一个auth方法进行校验。 ? // 连接本地的 Redis 服务Jedis jedis = new Jedis("localhost");//jedis.auth("souvc");System.out.println("连接本地的 Redis 服务成功!"); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |