redis高級使用

来源:https://www.cnblogs.com/zhengjunjie/archive/2020/01/14/12194120.html
-Advertisement-
Play Games

Redis常用的數據類型: String Hash List Set zSet Sorted set String類型 判斷是否有key所對應的值,有則返回true,沒有則返回false redisTemplate.hasKey(key) 有則取出key值所對應的值 redisTemplate.op ...


Redis常用的數據類型:  String
 
Hash
 
 List
 
 Set
 
 zSet
 
 Sorted set
 
String類型 判斷是否有key所對應的值,有則返回true,沒有則返回false redisTemplate.hasKey(key)
有則取出key值所對應的值 redisTemplate.opsForValue().get(key)
刪除單個key值 redisTemplate.delete(key)
批量刪除key redisTemplate.delete(keys) //其中keys:Collection<K> keys
將當前傳入的key值序列化為byte[]類型 redisTemplate.dump(key)
設置過期時間 public Boolean expire(String key, long timeout, TimeUnit unit) {    return redisTemplate.expire(key, timeout, unit); }  public Boolean expireAt(String key, Date date) {    return redisTemplate.expireAt(key, date);  } 查找匹配的key值,返回一個Set集合類型 public Set<String> getPatternKey(String pattern) {    return redisTemplate.keys(pattern);} 修改redis中key的名稱  public void renameKey(String oldKey, String newKey) {    redisTemplate.rename(oldKey, newKey);} 返回傳入key所存儲的值的類型 public DataType getKeyType(String key) {    return redisTemplate.type(key);} 如果舊值存在時,將舊值改為新值 public Boolean renameOldKeyIfAbsent(String oldKey, String newKey) {    return redisTemplate.renameIfAbsent(oldKey, newKey);} 從redis中隨機取出一個key redisTemplate.randomKey()
返回當前key所對應的剩餘過期時間  public Long getExpire(String key) {    return redisTemplate.getExpire(key);} 返回剩餘過期時間並且指定時間單位 public Long getExpire(String key, TimeUnit unit) {    return redisTemplate.getExpire(key, unit);} 將key持久化保存 public Boolean persistKey(String key) {    return redisTemplate.persist(key);} 將當前資料庫的key移動到指定redis中資料庫當中 public Boolean moveToDbIndex(String key, int dbIndex) {    return redisTemplate.move(key, dbIndex);} 設置當前的key以及value值 redisTemplate.opsForValue().set(key, value)
設置當前的key以及value值並且設置過期時間 redisTemplate.opsForValue().set(key, value, timeout, unit)
返回key中字元串的子字元 public String getCharacterRange(String key, long start, long end) {    return redisTemplate.opsForValue().get(key, start, end);} 將舊的key設置為value,並且返回舊的key public String setKeyAsValue(String key, String value) {    return redisTemplate.opsForValue().getAndSet(key, value);} 批量獲取值  public List<String> multiGet(Collection<String> keys) {    return redisTemplate.opsForValue().multiGet(keys); } 在原有的值基礎上新增字元串到末尾 redisTemplate.opsForValue().append(key, value)
以增量的方式將double值存儲在變數中  public Double incrByDouble(String key, double increment) {    return redisTemplate.opsForValue().increment(key, increment); } 通過increment(K key, long delta)方法以增量方式存儲long值(正值則自增,負值則自減) public Long incrBy(String key, long increment) {    return redisTemplate.opsForValue().increment(key, increment);} 如果對應的map集合名稱不存在,則添加否則不做修改 Map valueMap = new HashMap();  valueMap.put("valueMap1","map1");  valueMap.put("valueMap2","map2");  valueMap.put("valueMap3","map3");  redisTemplate.opsForValue().multiSetIfAbsent(valueMap); 設置map集合到redis Map valueMap = new HashMap();  valueMap.put("valueMap1","map1");  valueMap.put("valueMap2","map2");  valueMap.put("valueMap3","map3");  redisTemplate.opsForValue().multiSet(valueMap);  獲取字元串的長度 redisTemplate.opsForValue().size(key)
用 value 參數覆寫給定 key 所儲存的字元串值,從偏移量 offset 開始 redisTemplate.opsForValue().set(key, value, offset) 重新設置key對應的值,如果存在返回false,否則返回true redisTemplate.opsForValue().setIfAbsent(key, value) 將值 value 關聯到 key,並將 key 的過期時間設為 timeout redisTemplate.opsForValue().set(key, value, timeout, unit)
將二進位第offset位值變為value redisTemplate.opsForValue().setBit(key, offset, value) 對key所儲存的字元串值,獲取指定偏移量上的位(bit) redisTemplate.opsForValue().getBit(key, offset) Hash類型 Redis hash 是一個string類型的field和value的映射表,hash特別適合用於存儲對象。
Redis 中每個 hash 可以存儲 2^32 - 1 鍵值對(40多億)。 獲取變數中的指定map鍵是否有值,如果存在該map鍵則獲取值,沒有則返回null。 redisTemplate.opsForHash().get(key, field) 獲取變數中的鍵值對 public Map<Object, Object> hGetAll(String key) {    return redisTemplate.opsForHash().entries(key);} 新增hashMap值 redisTemplate.opsForHash().put(key, hashKey, value)
以map集合的形式添加鍵值對 public void hPutAll(String key, Map<String, String> maps) {    redisTemplate.opsForHash().putAll(key, maps);} 僅當hashKey不存在時才設置 public Boolean hashPutIfAbsent(String key, String hashKey, String value) {    return redisTemplate.opsForHash().putIfAbsent(key, hashKey, value);} 刪除一個或者多個hash表欄位 public Long hashDelete(String key, Object... fields) {    return redisTemplate.opsForHash().delete(key, fields);} 查看hash表中指定欄位是否存在 public boolean hashExists(String key, String field) {    return redisTemplate.opsForHash().hasKey(key, field);} 給哈希表key中的指定欄位的整數值加上增量increment public Long hashIncrBy(String key, Object field, long increment) {    return redisTemplate.opsForHash().increment(key, field, increment);}  public Double hIncrByDouble(String key, Object field, double delta) {    return redisTemplate.opsForHash().increment(key, field, delta);} 獲取所有hash表中欄位 redisTemplate.opsForHash().keys(key) 獲取hash表中欄位的數量 redisTemplate.opsForHash().size(key)
獲取hash表中存在的所有的值 public List<Object> hValues(String key) {    return redisTemplate.opsForHash().values(key);} 匹配獲取鍵值對,ScanOptions.NONE為獲取全部鍵對 public Cursor<Entry<Object, Object>> hashScan(String key, ScanOptions options) {    return redisTemplate.opsForHash().scan(key, options);} List類型
通過索引獲取列表中的元素 redisTemplate.opsForList().index(key, index)
獲取列表指定範圍內的元素(start開始位置, 0是開始位置,end 結束位置, -1返回所有) redisTemplate.opsForList().range(key, start, end) 存儲在list的頭部,即添加一個就把它放在最前面的索引處 redisTemplate.opsForList().leftPush(key, value) 把多個值存入List中(value可以是多個值,也可以是一個Collection value) redisTemplate.opsForList().leftPushAll(key, value) List存在的時候再加入 redisTemplate.opsForList().leftPushIfPresent(key, value) 如果pivot處值存在則在pivot前面添加 redisTemplate.opsForList().leftPush(key, pivot, value) 按照先進先出的順序來添加(value可以是多個值,或者是Collection var2) redisTemplate.opsForList().rightPush(key, value) redisTemplate.opsForList().rightPushAll(key, value) 在pivot元素的右邊添加值 redisTemplate.opsForList().rightPush(key, pivot, value) 設置指定索引處元素的值 redisTemplate.opsForList().set(key, index, value) 移除並獲取列表中第一個元素(如果列表沒有元素會阻塞列表直到等待超時或發現可彈出元素為止) redisTemplate.opsForList().leftPop(key) redisTemplate.opsForList().leftPop(key, timeout, unit) 移除並獲取列表最後一個元素 redisTemplate.opsForList().rightPop(key) redisTemplate.opsForList().rightPop(key, timeout, unit) 從一個隊列的右邊彈出一個元素並將這個元素放入另一個指定隊列的最左邊 redisTemplate.opsForList().rightPopAndLeftPush(sourceKey, destinationKey) redisTemplate.opsForList().rightPopAndLeftPush(sourceKey, destinationKey, timeout, unit) 刪除集合中值等於value的元素(index=0, 刪除所有值等於value的元素; index>0, 從頭部開始刪除第一個值等於value的元素; index<0, 從尾部開始刪除第一個值等於value的元素) redisTemplate.opsForList().remove(key, index, value) 將List列表進行剪裁 redisTemplate.opsForList().trim(key, start, end) 獲取當前key的List列表長度 redisTemplate.opsForList().size(key) Set類型
添加元素 redisTemplate.opsForSet().add(key, values) 移除元素(單個值、多個值) redisTemplate.opsForSet().remove(key, values) 刪除並且返回一個隨機的元素 redisTemplate.opsForSet().pop(key) 獲取集合的大小 redisTemplate.opsForSet().size(key) 判斷集合是否包含value redisTemplate.opsForSet().isMember(key, value) 獲取兩個集合的交集(key對應的無序集合與otherKey對應的無序集合求交集) redisTemplate.opsForSet().intersect(key, otherKey) 獲取多個集合的交集(Collection var2) redisTemplate.opsForSet().intersect(key, otherKeys) key集合與otherKey集合的交集存儲到destKey集合中(其中otherKey可以為單個值或者集合) redisTemplate.opsForSet().intersectAndStore(key, otherKey, destKey) key集合與多個集合的交集存儲到destKey無序集合中 redisTemplate.opsForSet().intersectAndStore(key, otherKeys, destKey) 獲取兩個或者多個集合的並集(otherKeys可以為單個值或者是集合) redisTemplate.opsForSet().union(key, otherKeys) key集合與otherKey集合的並集存儲到destKey中(otherKeys可以為單個值或者是集合) redisTemplate.opsForSet().unionAndStore(key, otherKey, destKey) 獲取兩個或者多個集合的差集(otherKeys可以為單個值或者是集合) redisTemplate.opsForSet().difference(key, otherKeys) 差集存儲到destKey中(otherKeys可以為單個值或者集合) redisTemplate.opsForSet().differenceAndStore(key, otherKey, destKey) 隨機獲取集合中的一個元素 redisTemplate.opsForSet().randomMember(key) 獲取集合中的所有元素 redisTemplate.opsForSet().members(key) 隨機獲取集合中count個元素 redisTemplate.opsForSet().randomMembers(key, count) 獲取多個key無序集合中的元素(去重),count表示個數 redisTemplate.opsForSet().distinctRandomMembers(key, count) 遍歷set類似於Interator(ScanOptions.NONE為顯示所有的) redisTemplate.opsForSet().scan(key, options) zSet類型
ZSetOperations提供了一系列方法對有序集合進行操作
添加元素(有序集合是按照元素的score值由小到大進行排列) redisTemplate.opsForZSet().add(key, value, score) 刪除對應的value,value可以為多個值 redisTemplate.opsForZSet().remove(key, values) 增加元素的score值,並返回增加後的值 redisTemplate.opsForZSet().incrementScore(key, value, delta) 返回元素在集合的排名,有序集合是按照元素的score值由小到大排列 redisTemplate.opsForZSet().rank(key, value) 返回元素在集合的排名,按元素的score值由大到小排列 redisTemplate.opsForZSet().reverseRank(key, value) 獲取集合中給定區間的元素(start 開始位置,end 結束位置, -1查詢所有) redisTemplate.opsForZSet().reverseRangeWithScores(key, start,end) 按照Score值查詢集合中的元素,結果從小到大排序 redisTemplate.opsForZSet().reverseRangeByScore(key, min, max) redisTemplate.opsForZSet().reverseRangeByScoreWithScores(key, min, max)//返回值為:Set<ZSetOperations.TypedTuple<V>> 從高到低的排序集中獲取分數在最小和最大值之間的元素 redisTemplate.opsForZSet().reverseRangeByScore(key, min, max, start, end) 根據score值獲取集合元素數量 redisTemplate.opsForZSet().count(key, min, max) 獲取集合的大小 redisTemplate.opsForZSet().size(key) redisTemplate.opsForZSet().zCard(key) 獲取集合中key、value元素對應的score值 redisTemplate.opsForZSet().score(key, value) 移除指定索引位置處的成員 redisTemplate.opsForZSet().removeRange(key, start, end) 移除指定score範圍的集合成員 redisTemplate.opsForZSet().removeRangeByScore(key, min, max) 獲取key和otherKey的並集並存儲在destKey中(其中otherKeys可以為單個字元串或者字元串集合) redisTemplate.opsForZSet().unionAndStore(key, otherKey, destKey) 獲取key和otherKey的交集並存儲在destKey中(其中otherKeys可以為單個字元串或者字元串集合) redisTemplate.opsForZSet().intersectAndStore(key, otherKey, destKey) 遍歷集合(和iterator一模一樣) Cursor<TypedTuple<Object>> scan = opsForZSet.scan("test3", ScanOptions.NONE);        while (scan.hasNext()){            ZSetOperations.TypedTuple<Object> item = scan.next();            System.out.println(item.getValue() + ":" + item.getScore());        }
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前段時間參加了IAS2019(互聯網架構峰會),本次峰會以中台為主題,所以又稱中台戰略大會,據說是全國首屆關於中台戰略的會議,會議上有許多優秀的企業架構師帶來了他們各自在實踐中台過程中的心得。本文就筆者對自己參與的會場的情況做一些分享,同時也寫寫自己參會以及查閱相關資料後關於中台這一概念的理解和體會 ...
  • 微服務可以幫我們成就更大的夢想,為什麼呢?請看老兵哥近些年推廣微服務架構過程中收穫的心得體會! ...
  • 一、資料庫中時間類型 1.三種時間類型:DateTimeField、DataField、TimeField三種類型;在使用之前需先導入import django.utils.timezone包 2.該三種類型分別對應這Datetime、Data、Time三種對象; 3.時間類型,三個屬性,auto_ ...
  • 一、定義 是`JDK ThreadLocal`意思就是本地線程的意思。 1.1 是什麼? 要想知道他是個啥,我們看看 的源碼(基於 )中對這個類的介紹: 大致能夠總結出: 1. 可以給我們提供一個線程內的局部變數,而且這個變數與一般的變數還不同,它是每個線程獨有的,與其他線程互不幹擾的; 1. 與普 ...
  • 寫在前面 考研在即,想多瞭解考研er的想法,就是去找學長學姐或者去網上搜索,貼吧就是一個好地方。而藉助強大的工具可以快速從網路魚龍混雜的信息中得到有價值的信息。雖然網上有很多爬取百度貼吧的教程和例子,但是貼吧規則更新快,目的不一樣,爬取的內容也不一樣,所以就有了這個工具。 目的 爬取1000條帖子→ ...
  • 前言: 事務處理的本質 在學習事務處理前,需要明確一點: 資料庫操作最終都要使用到JDBC,那麼無論上層如何封裝,底層都是調用Connection的commit,rollback來完成 煩人的事務處理: 在日常開發中,數據訪問層(DAO)必然需要進行事務的處理,但是我們會發現,事務處理的代碼通常是簡 ...
  • Java操作Jxl實現.xsl及.xsls兩種數據表格進行批量導入數據到SQL server資料庫。 本文實現背景Web項目:前臺用的框架是Easyui+Bootstrap結合使用,需要引入相應的Js、Css文件。頁面:Jsp、攔截請求:Servlet、邏輯處理:ClassBean、資料庫:SQLs ...
  • 2020-01-14 相信很多初學小伙伴都會遇到二維列表求解所有元素之和問題,下麵給出兩種兩種常見的求和方法。 方法1: 思想:遍歷整個二維列表元素,然後將所有元素加起來 1 def Sum_matrix(matrix): 2 sum=0 3 for i in range(len(matrix)): ...
一周排行
    -Advertisement-
    Play Games
  • 前言 在我們開發過程中基本上不可或缺的用到一些敏感機密數據,比如SQL伺服器的連接串或者是OAuth2的Secret等,這些敏感數據在代碼中是不太安全的,我們不應該在源代碼中存儲密碼和其他的敏感數據,一種推薦的方式是通過Asp.Net Core的機密管理器。 機密管理器 在 ASP.NET Core ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 順序棧的介面程式 目錄順序棧的介面程式頭文件創建順序棧入棧出棧利用棧將10進位轉16進位數驗證 頭文件 #include <stdio.h> #include <stdbool.h> #include <stdlib.h> 創建順序棧 // 指的是順序棧中的元素的數據類型,用戶可以根據需要進行修改 ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • C總結與剖析:關鍵字篇 -- <<C語言深度解剖>> 目錄C總結與剖析:關鍵字篇 -- <<C語言深度解剖>>程式的本質:二進位文件變數1.變數:記憶體上的某個位置開闢的空間2.變數的初始化3.為什麼要有變數4.局部變數與全局變數5.變數的大小由類型決定6.任何一個變數,記憶體賦值都是從低地址開始往高地 ...
  • 如果讓你來做一個有狀態流式應用的故障恢復,你會如何來做呢? 單機和多機會遇到什麼不同的問題? Flink Checkpoint 是做什麼用的?原理是什麼? ...
  • C++ 多級繼承 多級繼承是一種面向對象編程(OOP)特性,允許一個類從多個基類繼承屬性和方法。它使代碼更易於組織和維護,並促進代碼重用。 多級繼承的語法 在 C++ 中,使用 : 符號來指定繼承關係。多級繼承的語法如下: class DerivedClass : public BaseClass1 ...
  • 前言 什麼是SpringCloud? Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的開發便利性簡化了分散式系統的開發,比如服務註冊、服務發現、網關、路由、鏈路追蹤等。Spring Cloud 並不是重覆造輪子,而是將市面上開發得比較好的模塊集成進去,進行封裝,從 ...
  • class_template 類模板和函數模板的定義和使用類似,我們已經進行了介紹。有時,有兩個或多個類,其功能是相同的,僅僅是數據類型不同。類模板用於實現類所需數據的類型參數化 template<class NameType, class AgeType> class Person { publi ...
  • 目錄system v IPC簡介共用記憶體需要用到的函數介面shmget函數--獲取對象IDshmat函數--獲得映射空間shmctl函數--釋放資源共用記憶體實現思路註意 system v IPC簡介 消息隊列、共用記憶體和信號量統稱為system v IPC(進程間通信機制),V是羅馬數字5,是UNI ...