欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java中使用Jedis操作Redis的示例代碼

 更新時間:2016年12月30日 15:07:32   作者:殘劍_  
本篇文章主要介紹了Java中使用Jedis操作Redis的示例代碼,具有一定的參考價值,有興趣的可以了解一下。

使用Java操作Redis需要jedis-2.1.0.jar,下載地址:jedis-2.1.0.jar

如果需要使用Redis連接池的話,還需commons-pool-1.5.4.jar,下載地址:commons-pool-1.5.4.jar

package com.test;

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

import org.junit.Before;
import org.junit.Test;

import redis.clients.jedis.Jedis;

public class TestRedis {
  private Jedis jedis; 
  
  @Before
  public void setup() {
    //連接redis服務器,192.168.0.100:6379
    jedis = new Jedis("192.168.0.100", 6379);
    //權限認證
    jedis.auth("admin"); 
  }
  
  /**
   * redis存儲字符串
   */
  @Test
  public void testString() {
    //-----添加數據---------- 
    jedis.set("name","xinxin");//向key-->name中放入了value-->xinxin 
    System.out.println(jedis.get("name"));//執(zhí)行結果:xinxin 
    
    jedis.append("name", " is my lover"); //拼接
    System.out.println(jedis.get("name")); 
    
    jedis.del("name"); //刪除某個鍵
    System.out.println(jedis.get("name"));
    //設置多個鍵值對
    jedis.mset("name","liuling","age","23","qq","476777XXX");
    jedis.incr("age"); //進行加1操作
    System.out.println(jedis.get("name") + "-" + jedis.get("age") + "-" + jedis.get("qq"));
    
  }
  
  /**
   * redis操作Map
   */
  @Test
  public void testMap() {
    //-----添加數據---------- 
    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,執(zhí)行結果:[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)); 
    } 
  }
  
  /** 
   * jedis操作List 
   */ 
  @Test 
  public void testList(){ 
    //開始前,先移除所有的內容 
    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操作Set 
   */ 
  @Test 
  public void testSet(){ 
    //添加 
    jedis.sadd("user","liuling"); 
    jedis.sadd("user","xinxin"); 
    jedis.sadd("user","ling"); 
    jedis.sadd("user","zhangxinxin");
    jedis.sadd("user","who"); 
    //移除noname 
    jedis.srem("user","who"); 
    System.out.println(jedis.smembers("user"));//獲取所有加入的value 
    System.out.println(jedis.sismember("user", "who"));//判斷 who 是否是user集合的元素 
    System.out.println(jedis.srandmember("user")); 
    System.out.println(jedis.scard("user"));//返回集合的元素個數 
  } 
 
  @Test 
  public void test() throws InterruptedException { 
    //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)); 
  } 
  
  @Test
  public void testRedisPool() {
    RedisUtil.getJedis().set("newname", "中文測試");
    System.out.println(RedisUtil.getJedis().get("newname"));
  }
}

Redis連接池:

package com.test;

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

public final class RedisUtil {
  
  //Redis服務器IP
  private static String ADDR = "192.168.0.100";
  
  //Redis的端口號
  private static int PORT = 6379;
  
  //訪問密碼
  private static String AUTH = "admin";
  
  //可用連接實例的最大數目,默認值為8;
  //如果賦值為-1,則表示不限制;如果pool已經分配了maxActive個jedis實例,則此時pool的狀態(tài)為exhausted(耗盡)。
  private static int MAX_ACTIVE = 1024;
  
  //控制一個pool最多有多少個狀態(tài)為idle(空閑的)的jedis實例,默認值也是8。
  private static int MAX_IDLE = 200;
  
  //等待可用連接的最大時間,單位毫秒,默認值為-1,表示永不超時。如果超過等待時間,則直接拋出JedisConnectionException;
  private static int MAX_WAIT = 10000;
  
  private static int TIMEOUT = 10000;
  
  //在borrow一個jedis實例時,是否提前進行validate操作;如果為true,則得到的jedis實例均是可用的;
  private static boolean TEST_ON_BORROW = true;
  
  private static JedisPool jedisPool = null;
  
  /**
   * 初始化Redis連接池
   */
  static {
    try {
      JedisPoolConfig config = new JedisPoolConfig();
      config.setMaxActive(MAX_ACTIVE);
      config.setMaxIdle(MAX_IDLE);
      config.setMaxWait(MAX_WAIT);
      config.setTestOnBorrow(TEST_ON_BORROW);
      jedisPool = new JedisPool(config, ADDR, PORT, TIMEOUT, AUTH);
    } catch (Exception e) {
      e.printStackTrace();
    }
  }
  
  /**
   * 獲取Jedis實例
   * @return
   */
  public synchronized static Jedis getJedis() {
    try {
      if (jedisPool != null) {
        Jedis resource = jedisPool.getResource();
        return resource;
      } else {
        return null;
      }
    } catch (Exception e) {
      e.printStackTrace();
      return null;
    }
  }
  
  /**
   * 釋放jedis資源
   * @param jedis
   */
  public static void returnResource(final Jedis jedis) {
    if (jedis != null) {
      jedisPool.returnResource(jedis);
    }
  }
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Java實現五子棋游戲單機版(1.0)

    Java實現五子棋游戲單機版(1.0)

    這篇文章主要為大家詳細介紹了Java實現五子棋游戲單機版,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • Java List雙擊事件實現方法

    Java List雙擊事件實現方法

    這篇文章主要介紹了Java List雙擊事件實現方法,需要的朋友可以參考下
    2014-09-09
  • SpringMVC配置404踩坑記錄

    SpringMVC配置404踩坑記錄

    本文主要介紹了SpringMVC配置404踩坑記錄,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-03-03
  • Springboot詳解如何整合使用Thymeleaf

    Springboot詳解如何整合使用Thymeleaf

    這篇文章主要分享了Spring Boot整合使用Thymeleaf,Thymeleaf是新一代的Java模板引擎,類似于Velocity、FreeMarker等傳統(tǒng)引擎,關于其更多相關內容,需要的小伙伴可以參考一下
    2022-06-06
  • Java中數組array和列表list相互轉換

    Java中數組array和列表list相互轉換

    這篇文章主要介紹了Java中數組array和列表list相互轉換,在Java中,可以將數組(array)和列表(list)相互轉換,但需要注意一些細節(jié)和限制,本文通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2023-09-09
  • 詳解Spring如何解決循環(huán)引用的問題

    詳解Spring如何解決循環(huán)引用的問題

    在Spring框架中,當兩個或多個Bean之間存在相互依賴關系時,可能會導致循環(huán)引用的問題,循環(huán)引用指的是兩個或多個Bean之間互相依賴,形成一個循環(huán)鏈,本文將和大家一起探討Spring如何解決循環(huán)引用的問題,感興趣的小伙伴跟著小編一起來看看吧
    2023-08-08
  • 你知道怎么用Spring的三級緩存解決循環(huán)依賴嗎

    你知道怎么用Spring的三級緩存解決循環(huán)依賴嗎

    這篇文章主要為大家詳細介紹了Spring的三級緩存解決循環(huán)依賴,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • 解決nacos啟動報錯Server check fail, please check server localhost ,port 9848 is available的問題

    解決nacos啟動報錯Server check fail, please che

    這篇文章主要介紹了nacos啟動 Server check fail, please check server localhost ,port 9848 is available的錯誤原因以及解決方法,需要的朋友可以參考下
    2023-09-09
  • MyBatis-Plus 之selectMaps、selectObjs、selectCount、selectOne的使用

    MyBatis-Plus 之selectMaps、selectObjs、selectCount、selectO

    本文主要介紹了MyBatis-Plus 之selectMaps、selectObjs、selectCount、selectOne的使用,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Spring與Web整合實例

    Spring與Web整合實例

    下面小編就為大家?guī)硪黄猄pring與Web整合實例。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07

最新評論