开发者社区> 二进制循环> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

Java使用Redis

简介: Redis 安装 Window 下安装 下载地址:https://github.com/MSOpenTech/redis/releases 下载解压后,启动服务端,使用java操作red...
+关注继续查看

Redis 安装
Window 下安装
下载地址:https://github.com/MSOpenTech/redis/releases

下载解压后,启动服务端,使用java操作redis需要先启动服务器

下载java操作redis的jar包

Mavne依赖地址

<!-- https://mvnrepository.com/artifact/redis.clients/jedis -->
<dependency>
    <groupId>redis.clients</groupId>
    <artifactId>jedis</artifactId>
    <version>2.9.0</version>
</dependency>

或者下载地址http://central.maven.org/maven2/redis/clients/jedis/2.9.0/jedis-2.9.0.jar

redis五种数据类型,String,List,Hash,Set,有序Set

package com.wy.test;

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;

import org.junit.Test;

import redis.clients.jedis.Jedis;

public class TestRedis {

    private static  Jedis jedis;

    static {
        //连接服务器
        jedis = new Jedis("127.0.0.1",6379);
        //权限认证
//      jedis.auth("");

    }

    //字符串操作
    @Test
    public void testString() {
        jedis.set("name", "沪旦铭");
        System.out.println( jedis.get("name") );
        //追加操作
        jedis.append("name", "是我的名字");
        System.out.println( jedis.get("name") );
        //删除键
        Long result = jedis.del("name2");
        System.out.println( result ); //返回Long型  1表示成功0失败
        //设置多个键值对
        jedis.mset("age","20","addr","湖南");
        //获取多个键  返回一个列表类型  [沪旦铭是我的名字, 20, 湖南]
        System.out.println( jedis.mget("name","age","addr"));

    }

    //哈希操作Hash
    @Test
    public void testHash() {
        Map<String,String> map = new HashMap<String,String>();
        map.put("name", "沪旦铭");
        map.put("age", "20");
        //存储数据
        jedis.hmset("user", map);
        //读取数据  返回一个列表类型 [沪旦铭, 20]
        System.out.println( jedis.hmget("user", "name","age") );
        //HKEYS key 获取所有哈希表中的字段    返回一个列表[name, age]
        System.out.println( jedis.hkeys("user") );
        //HVALS key 获取哈希表中所有值
        System.out.println( jedis.hvals("user") );
        //HLEN key 获取哈希表中字段的数量
        System.out.println( jedis.hlen("user") );
        //获取所有的键  迭代操作
        Iterator<String> iter = jedis.hkeys("user").iterator();
        while(iter.hasNext()) {
            String key = iter.next();
            System.out.println( key+"--"+jedis.hmget("user", key) );
        }

    }

    //List操作
    @Test
    public void testList() {
        //开始前,先移除所有的内容  
        jedis.del("Programming language");

        //LPUSH key value1 [value2] 将一个或多个值插入到列表头部
        jedis.lpush("Programming language", "Java");
        jedis.lpush("Programming language", "Python");
        jedis.lpush("Programming language", "C++");
        //获取数据  返回一个list [Python, Java]
        //第一个是key,第二个是起始位置,第三个是结束位置  
        //其中 0 表示列表的第一个元素, 1 表示列表的第二个元素,以此类推。 
        //你也可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,以此类推。
        System.out.println( jedis.lrange("Programming language",  0, -1) );
        //LPUSHX key value 将一个值插入到已存在的列表头部
        jedis.lpushx("Programming language", "php");
        System.out.println( jedis.lrange("Programming language",  0, -1) );
        //RPUSH key value1 [value2] 在列表中添加一个或多个值
        jedis.rpush("Programming language", "C");
        System.out.println( jedis.lrange("Programming language",  0, -1) );
        //输出情况
//      [C++, Python, Java]
//      [php, C++, Python, Java]
//      [php, C++, Python, Java, C]
    }


    //Set操作
    @Test
    public void testSet() {
        //向集合添加一个或多个成员
        jedis.sadd("webSite", "阿里巴巴","网易");
        jedis.sadd("webSite", "腾讯");
        //SCARD key 获取集合的成员数
        System.out.println( jedis.scard("webSite") );
        //SMEMBERS key 返回集合中的所有成员  返回类型列表[阿里巴巴, 腾讯, 网易]注意顺序不唯一
        System.out.println( jedis.smembers("webSite") );
        //SSCAN key cursor [MATCH pattern] [COUNT count] 迭代集合中的元素
        System.out.println(jedis.sscan("webSite", "0") );


    }

    //sorted set有序Set
    @Test
    public void testSortSet() {
//      Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员。
//      不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
//      有序集合的成员是唯一的,但分数(score)却可以重复。
        jedis.zadd("city", 0, "北京");
        jedis.zadd("city", 1, "上海");
        jedis.zadd("city", 2, "杭州");

        //ZCARD key 获取有序集合的成员数
        System.out.println( jedis.zcard("city") );
        //ZREVRANK key member 返回有序集合中指定成员的排名,有序集成员按分数值递减(从大到小)排序  java中的方法是zrevrangeByScore
        System.out.println( jedis.zrevrangeByScore("city", 5, 0) );


    }
}

参考资料:
1. https://www.cnblogs.com/liuling/p/2014-4-19-04.html
2. http://www.runoob.com/redis/redis-intro.html

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
在java中使用redis
在java中使用redis很简单,只需要添加jedist.jar,通过它的api就可以了。而且,api和redis的语法几乎完全相同。以下简单的测试: 参考:http://www.runoob.com/redis/redis-java.
845 0
Redis之集群环境搭建
前面文章介绍了Redis的主从复制,虽然该模式能够在一定程度上提高系统的稳定性,但是在数据访问量比较大的情况下,单个master应付起来还是比较吃力的,这时我们可以考虑将redis集群部署,本文就来重点给大家介绍下Redis的集群部署操作。
130 0
redis集群的搭建
redis集群的搭建 一.为什么使用redis? redis是一种典型的no-sql,工作在内存中,这就意味着它的读写效率是非常高的。所以大数据量的访问导致db的压力增大,所以为了业务的稳定,需要在db层上使用多级的redis提供缓冲区 二.为什么使用redis-cluster? redis是一个内存数据库,这就意味着单个redis数据库的容量不能超过服务器的内存。
2157 0
Linux——搭建Redis集群
  上一篇文章介绍到redis的安装和配置,有时候我们需要考虑负载均衡或者容灾机制,在某台机器宕机的时候不能影响程序的正常工作,因此今天和大家共同搭建一些redis集群。
1190 0
Redis 复制与集群
<div class="markdown_views"> <h2 id="复制">复制</h2> <p>为提高高可用性,排除单点故障,redis支持主从复制功能。 <br> 其整体结构是一个有向无环图。</p> <h3 id="同步方式">同步方式</h3> <p>分为两种:</p> <ul> <li>全同步 <br> 全同步是第一次从机连主机是进行的同步,主机会生
2091 0
Redis复制与可扩展集群搭建
Redis复制流程概述 Redis的复制功能是完全建立在之前我们讨论过的基于内存快照的持久化策略基础上的,也就是说无论你的持久化策略选择的是什么,只要用到了Redis的复制功能,就一定会有内存快照发生,那么首先要注意你的系统内存容量规划,原因可以参考我上一篇文章中提到的Redis磁盘IO问题。
1089 0
38
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载