21 在Java中使用Redis

连接虚拟机的Redis时,要为Redis设置密码

  • 1 String

import redis.clients.jedis.Jedis;

public class Test {
    private Jedis jedis; 
    public static void main(String[] args) {
        //连接本地的 Redis 服务
        Jedis jedis = new Jedis("192.168.1.90",6379);
        jedis.auth("1");  

        //查看服务是否运行
        System.out.println("服务正在运行: "+jedis.ping());
        System.out.println("连接成功");
        
        //向key-->name中放入了value-->gp6  
        jedis.set("name","gp6");
        //执行结果:gp6  
        System.out.println(jedis.get("name"));
        
        //拼接
        jedis.append("name", " is my lover");
        //执行结果:gp6  is my lover
        System.out.println(jedis.get("name")); 
        
        jedis.del("name");  //删除某个键
        //执行结果:null
        System.out.println(jedis.get("name"));
        
        //设置多个键值对
        jedis.mset("name","gp6","age","24","qq","6266XXX01");
        //进行加1操作
        jedis.incr("age"); 
        //执行结果:gp6-25-6266XXX01
        System.out.println(jedis.get("name") + "-" + jedis.get("age") + "-" + jedis.get("qq"));
    }
}

2 Map(Hash)

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

import redis.clients.jedis.Jedis;

public class Test {
    private Jedis jedis; 
    public static void main(String[] args) {
        //连接本地的 Redis 服务
        Jedis jedis = new Jedis("192.168.1.90",6379);
        jedis.auth("1");  

        //查看服务是否运行
        System.out.println("服务正在运行: "+jedis.ping());
        System.out.println("连接成功");
        
        //-----添加数据----------  
        Map<String, String> map = new HashMap<String, String>();
        map.put("name", "gp6");
        map.put("age", "24");
        map.put("qq", "6266156XX");
        jedis.hmset("user",map);
        
        //取出user中的name,执行结果:[minxr]-->注意结果是一个泛型的List  
        //第一个参数是存入redis中map对象的key,后面跟的是放入map中的对象的key,后面的key可以跟多个,是可变参数  
        List<String> rsmap = jedis.hmget("user", "name", "age", "qq");
        //执行结果:[gp6, 24, 6266156XX]
        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(); 
            //执行两次,第一次结果:qq:[6266156XX]
            //执行两次,第二次结果:name:[gp6]
            System.out.println(key+":"+jedis.hmget("user",key));  
        }  
    }
}

3 List

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

import redis.clients.jedis.Jedis;

public class Test {
    private Jedis jedis; 
    public static void main(String[] args) {
        //连接本地的 Redis 服务
        Jedis jedis = new Jedis("192.168.1.90",6379);
        jedis.auth("1");  

        //查看服务是否运行
        System.out.println("服务正在运行: "+jedis.ping());
        System.out.println("连接成功");
        
        //开始前,先移除所有的内容  
        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表示取得所有 
        
        //执行结果:[hibernate, struts, spring]
        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");
        //执行结果:[spring, struts, hibernate]
        System.out.println(jedis.lrange("java framework",0,-1));
    }
}

  • 4 set

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

import redis.clients.jedis.Jedis;

public class Test {
    private Jedis jedis; 
    public static void main(String[] args) {
        //连接本地的 Redis 服务
        Jedis jedis = new Jedis("192.168.1.90",6379);
        jedis.auth("1");  

        //查看服务是否运行
        System.out.println("服务正在运行: "+jedis.ping());
        System.out.println("连接成功");
        
        //添加  
        jedis.sadd("user1","gp6");  
        jedis.sadd("user1","carry");  
        jedis.sadd("user1","gao");  
        jedis.sadd("user1","liu");
        jedis.sadd("user1","who");  
        
        //移除noname  
        jedis.srem("user1","who");  
        //执行结果:[carry, gao, liu, gp6]
        System.out.println(jedis.smembers("user1"));//获取所有加入的value  
        //执行结果:false
        System.out.println(jedis.sismember("user1", "who"));//判断 who 是否是user1集合的元素 
        //执行结果:carry
        System.out.println(jedis.srandmember("user1"));  
        //执行结果:4
        System.out.println(jedis.scard("user1"));//返回集合的元素个数  
    }
}

5 模拟Redis事务


import java.sql.*;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Set;

import org.json.JSONObject;
import org.json.JSONString;

import redis.clients.jedis.Jedis;
import redis.clients.jedis.Transaction;

public class Test {
    private Jedis jedis; 
    public static void main(String[] args) {
        //连接本地的 Redis 服务
        Jedis jedis = new Jedis("192.168.1.90",6379);
        System.out.println("Redis连接成功");
        
        //开启事务
        Transaction transaction = jedis.multi();
        
        transaction.set("k6", "v6");
        transaction.set("k7", "v7");
        
        //执行事务
        transaction.exec();
        
        //放弃事务
        //transaction.discard();
    }
}

6 Watch监控

import redis.clients.jedis.Jedis;
import redis.clients.jedis.Transaction;

public class TestTransaction {
    public boolean transMethod() {
        Jedis jedis = new Jedis("192.168.1.90",6379);
        int balance;// 可用余额
        int debt;// 欠额
        int amtToSubtract = 10;// 实刷额度
        System.out.println(jedis.get("k4"));

        jedis.watch("balance");
        // jedis.set("balance","5");//此句不该出现,模拟其他程序已经修改了该条目,也可以在redis里面直接修改
        balance = Integer.parseInt(jedis.get("balance"));

        if (balance < amtToSubtract) {
            jedis.unwatch();
            System.out.println("modify");
            return false;
        } else {
            System.out.println("***********transaction");
            Transaction transaction = jedis.multi();
            transaction.decrBy("balance", amtToSubtract);
            transaction.incrBy("debt", amtToSubtract);
            transaction.exec();
            balance = Integer.parseInt(jedis.get("balance"));
            debt = Integer.parseInt(jedis.get("debt"));

            System.out.println("*******" + balance);
            System.out.println("*******" + debt);
            return true;
        }
    }
    
    /**
       * 通俗点讲,watch命令就是标记一个键,如果标记了一个键, 在提交事务前如果该键被别人修改过,那事务就会失败,这种情况通常可以在程序中
       * 重新再尝试一次。
       * 首先标记了键balance,然后检查余额是否足够,不足就取消标记,并不做扣减; 足够的话,就启动事务进行更新操作,
       * 如果在此期间键balance被其它人修改, 那在提交事务(执行exec)时就会报错, 程序中通常可以捕获这类错误再重新执行一次,直到成功。
       */
    public static void main(String[] args) {
        TestTransaction testTransaction = new TestTransaction();
        boolean retValue = testTransaction.transMethod();
        System.err.println("=======" + retValue);
    }
}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,222评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,455评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,720评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,568评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,696评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,879评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,028评论 3 409
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,773评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,220评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,550评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,697评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,360评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,002评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,782评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,010评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,433评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,587评论 2 350