轉載文章(Redis中對key的操作)

来源:http://www.cnblogs.com/zpfbuaa/archive/2016/10/21/5985749.html
-Advertisement-
Play Games

轉載地址:http://www.cnblogs.com/stephen-liu74/archive/2012/03/26/2356951.html 一、概述: 在該系列的前幾篇博客中,主要講述的是與Redis數據類型相關的命令,如String、List、Set、Hashes和Sorted-Set。這 ...


轉載地址:http://www.cnblogs.com/stephen-liu74/archive/2012/03/26/2356951.html

一、概述:

      在該系列的前幾篇博客中,主要講述的是與Redis數據類型相關的命令,如String、List、Set、Hashes和Sorted-Set。這些命令都具有一個共同點,即所有的操作都是針對與Key關聯的Value的。而該篇博客將主要講述與Key相關的Redis命令。學習這些命令對於學習Redis是非常重要的基礎,也是能夠充分挖掘Redis潛力的利器。
      在該篇博客中,我們將一如既往的給出所有相關命令的明細列表和典型示例,以便於我們現在的學習和今後的查閱。

二、相關命令列表:

命令原型 時間複雜度 命令描述 返回值
KEYS pattern O(N) 時間複雜度中的N表示資料庫中Key的數量。獲取所有匹配pattern參數的Keys。需要說明的是,在我們的正常操作中應該儘量避免對該命令的調用,因為對於大型資料庫而言,該命令是非常耗時的,對Redis伺服器的性能打擊也是比較大的。pattern支持glob-style的通配符格式,如*表示任意一個或多個字元,?表示任意字元,[abc]表示方括弧中任意一個字母。 匹配模式的鍵列表。
DEL key [key ...] O(N) 時間複雜度中的N表示刪除的Key數量。從資料庫刪除中參數中指定的keys,如果指定鍵不存在,則直接忽略。還需要另行指出的是,如果指定的Key關聯的數據類型不是String類型,而是List、Set、Hashes和Sorted Set等容器類型,該命令刪除每個鍵的時間複雜度為O(M),其中M表示容器中元素的數量。而對於String類型的Key,其時間複雜度為O(1)。 實際被刪除的Key數量。
EXISTS key  O(1) 判斷指定鍵是否存在。 1表示存在,0表示不存在。
MOVE key db  O(1) 將當前資料庫中指定的鍵Key移動到參數中指定的資料庫中。如果該Key在目標資料庫中已經存在,或者在當前資料庫中並不存在,該命令將不做任何操作並返回0。   移動成功返回1,否則0。
RENAME key newkey  O(1) 為指定指定的鍵重新命名,如果參數中的兩個Keys的命令相同,或者是源Key不存在,該命令都會返回相關的錯誤信息。如果newKey已經存在,則直接覆蓋。   
RENAMENX key newkey O(1) 如果新值不存在,則將參數中的原值修改為新值。其它條件和RENAME一致。 1表示修改成功,否則0。
PERSIST key O(1) 如果Key存在過期時間,該命令會將其過期時間消除,使該Key不再有超時,而是可以持久化存儲。 1表示Key的過期時間被移出,0表示該Key不存在或沒有過期時間。
EXPIRE key seconds  O(1)  該命令為參數中指定的Key設定超時的秒數,在超過該時間後,Key被自動的刪除。如果該Key在超時之前被修改,與該鍵關聯的超時將被移除。  1表示超時被設置,0則表示Key不存在,或不能被設置。
EXPIREAT key timestamp  O(1)  該命令的邏輯功能和EXPIRE完全相同,唯一的差別是該命令指定的超時時間是絕對時間,而不是相對時間。該時間參數是Unix timestamp格式的,即從1970年1月1日開始所流經的秒數。 1表示超時被設置,0則表示Key不存在,或不能被設置。 
TTL key  O(1) 獲取該鍵所剩的超時描述。  返回所剩描述,如果該鍵不存在或沒有超時設置,則返回-1。
RANDOMKEY O(1)   從當前打開的資料庫中隨機的返回一個Key。 返回的隨機鍵,如果該資料庫是空的則返回nil。
TYPE key  O(1)  獲取與參數中指定鍵關聯值的類型,該命令將以字元串的格式返回。 返回的字元串為string、list、set、hash和zset,如果key不存在返回none。
SORT key [BY pattern] [LIMIT offset count] [GET pattern [GET pattern ...]] [ASC|DESC] [ALPHA] [STORE destination]  O(N+M*log(M))  這個命令相對來說是比較複雜的,因此我們這裡只是給出最基本的用法,有興趣的網友可以去參考redis的官方文檔。 返回排序後的原始列表。


三、命令示例:

   1. KEYS/RENAME/DEL/EXISTS/MOVE/RENAMENX:
    #在Shell命令行下啟動Redis客戶端工具。
    /> redis-cli
    #清空當前選擇的資料庫,以便於對後面示例的理解。
    redis 127.0.0.1:6379> flushdb
    OK
    #添加String類型的模擬數據。
    redis 127.0.0.1:6379> set mykey 2
    OK
    redis 127.0.0.1:6379> set mykey2 "hello"
    OK
    #添加Set類型的模擬數據。
    redis 127.0.0.1:6379> sadd mysetkey 1 2 3
    (integer) 3
    #添加Hash類型的模擬數據。
    redis 127.0.0.1:6379> hset mmtest username "stephen"
    (integer) 1
    #根據參數中的模式,獲取當前資料庫中符合該模式的所有key,從輸出可以看出,該命令在執行時並不區分與Key關聯的Value類型。
    redis 127.0.0.1:6379> keys my*
    1) "mysetkey"
    2) "mykey"
    3) "mykey2"
    #刪除了兩個Keys。
    redis 127.0.0.1:6379> del mykey mykey2
    (integer) 2
    #查看一下剛剛刪除的Key是否還存在,從返回結果看,mykey確實已經刪除了。
    redis 127.0.0.1:6379> exists mykey
    (integer) 0
    #查看一下沒有刪除的Key,以和上面的命令結果進行比較。
    redis 127.0.0.1:6379> exists mysetkey
    (integer) 1
    #將當前資料庫中的mysetkey鍵移入到ID為1的資料庫中,從結果可以看出已經移動成功。
    redis 127.0.0.1:6379> move mysetkey 1
    (integer) 1
    #打開ID為1的資料庫。
    redis 127.0.0.1:6379> select 1
    OK
    #查看一下剛剛移動過來的Key是否存在,從返回結果看已經存在了。
    redis 127.0.0.1:6379[1]> exists mysetkey
    (integer) 1
    #在重新打開ID為0的預設資料庫。
    redis 127.0.0.1:6379[1]> select 0
    OK
    #查看一下剛剛移走的Key是否已經不存在,從返回結果看已經移走。
    redis 127.0.0.1:6379> exists mysetkey
    (integer) 0
    #準備新的測試數據。    
    redis 127.0.0.1:6379> set mykey "hello"
    OK
    #將mykey改名為mykey1
    redis 127.0.0.1:6379> rename mykey mykey1
    OK
    #由於mykey已經被重新命名,再次獲取將返回nil。
    redis 127.0.0.1:6379> get mykey
    (nil)
    #通過新的鍵名獲取。
    redis 127.0.0.1:6379> get mykey1
    "hello"
    #由於mykey已經不存在了,所以返回錯誤信息。
    redis 127.0.0.1:6379> rename mykey mykey1
    (error) ERR no such key
    #為renamenx準備測試key
    redis 127.0.0.1:6379> set oldkey "hello"
    OK
    redis 127.0.0.1:6379> set newkey "world"
    OK
    #由於newkey已經存在,因此該命令未能成功執行。
    redis 127.0.0.1:6379> renamenx oldkey newkey
    (integer) 0
    #查看newkey的值,發現它也沒有被renamenx覆蓋。
    redis 127.0.0.1:6379> get newkey
    "world"
        
   2. PERSIST/EXPIRE/EXPIREAT/TTL:    
    #為後面的示例準備的測試數據。
    redis 127.0.0.1:6379> set mykey "hello"
    OK
    #將該鍵的超時設置為100秒。
    redis 127.0.0.1:6379> expire mykey 100
    (integer) 1
    #通過ttl命令查看一下還剩下多少秒。
    redis 127.0.0.1:6379> ttl mykey
    (integer) 97
    #立刻執行persist命令,該存在超時的鍵變成持久化的鍵,即將該Key的超時去掉。
    redis 127.0.0.1:6379> persist mykey
    (integer) 1
    #ttl的返回值告訴我們,該鍵已經沒有超時了。
    redis 127.0.0.1:6379> ttl mykey
    (integer) -1
    #為後面的expire命令準備數據。
    redis 127.0.0.1:6379> del mykey
    (integer) 1
    redis 127.0.0.1:6379> set mykey "hello"
    OK
    #設置該鍵的超時被100秒。
    redis 127.0.0.1:6379> expire mykey 100
    (integer) 1
    #用ttl命令看一下當前還剩下多少秒,從結果中可以看出還剩下96秒。
    redis 127.0.0.1:6379> ttl mykey
    (integer) 96
    #重新更新該鍵的超時時間為20秒,從返回值可以看出該命令執行成功。
    redis 127.0.0.1:6379> expire mykey 20
    (integer) 1
    #再用ttl確認一下,從結果中可以看出果然被更新了。
    redis 127.0.0.1:6379> ttl mykey
    (integer) 17
    #立刻更新該鍵的值,以使其超時無效。
    redis 127.0.0.1:6379> set mykey "world"
    OK
    #從ttl的結果可以看出,在上一條修改該鍵的命令執行後,該鍵的超時也無效了。
    redis 127.0.0.1:6379> ttl mykey
    (integer) -1

   3. TYPE/RANDOMKEY/SORT:
    #由於mm鍵在資料庫中不存在,因此該命令返回none。
    redis 127.0.0.1:6379> type mm
    none
    #mykey的值是字元串類型,因此返回string。
    redis 127.0.0.1:6379> type mykey
    string
    #準備一個值是set類型的鍵。
    redis 127.0.0.1:6379> sadd mysetkey 1 2
    (integer) 2
    #mysetkey的鍵是set,因此返回字元串set。
    redis 127.0.0.1:6379> type mysetkey
    set
    #返回資料庫中的任意鍵。
    redis 127.0.0.1:6379> randomkey
    "oldkey"
    #清空當前打開的資料庫。
    redis 127.0.0.1:6379> flushdb
    OK
    #由於沒有數據了,因此返回nil。
    redis 127.0.0.1:6379> randomkey
    (nil)

 

Redis TTL 命令以秒為單位返回 key 的剩餘過期時間。

語法

redis TTL 命令基本語法如下:

  1. redis 127.0.0.1:6379> TTL KEY_NAME

可用版本

>= 1.0.0

返回值

當 key 不存在時,返回 -2 。 當 key 存在但沒有設置剩餘生存時間時,返回 -1 。 否則,以毫秒為單位,返回 key 的剩餘生存時間。

註意:在 Redis 2.8 以前,當 key 不存在,或者 key 沒有設置剩餘生存時間時,命令都返回 -1 。

實例

  1. # 不存在的 key
  2.  
  3. redis> FLUSHDB
  4. OK
  5.  
  6. redis> TTL key
  7. (integer) -2
  8.  
  9.  
  10. # key 存在,但沒有設置剩餘生存時間
  11.  
  12. redis> SET key value
  13. OK
  14.  
  15. redis> TTL key
  16. (integer) -1
  17.  
  18.  
  19. # 有剩餘生存時間的 key
  20.  
  21. redis> EXPIRE key 10086
  22. (integer) 1
  23.  
  24. redis> TTL key
  25. (integer) 10084

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • ...
  • 一、資料庫管理-- 1.登陸資料庫 -- 2.查看資料庫伺服器所有資料庫 -- 3.創建資料庫 -- 4.創建帶有設置字元集的資料庫 -- 5.刪除資料庫 -- 6.查看預設字元集 -- 7.修改資料庫字元集 二、數據表的管理-- 1.選中資料庫 -- 2.查看表(一定要在選中資料庫之後) -- 3 ...
  • 全部文字見 http://www.centoscn.com/mysql/2016/0315/6844.html CentOS 7的yum源中沒有正常安裝mysql時的mysql-sever文件,需要去官網上下載 提示 Is this ok [y/d/N] 時輸入 y 然後開始聯網下包更新。。 成功安 ...
  • mysql datetime查詢異常 異常:Value '0000-00-00 00:00:00' can not be represented as java.sql.Timestamp (2011-05-25 11:38:40) 描述:非空無預設值的Datetime類型欄位,查詢時程式報以下錯誤 ...
  • 出處:kelvin19840813 的博客 http://www.cnblogs.com/kelvin19840813/ 您的支持是對博主最大的鼓勵,感謝您的認真閱讀。本文版權歸作者所有,歡迎轉載,但請保留該聲明。 資料庫版本是MySQL 5.6.23 為了防止泄密特意遮住表名字, 還有防止一些爬蟲 ...
  • 最近做一個項目,需要用centos做數據伺服器,用mysql資料庫,就需要安裝mysql資料庫,之前沒接觸過centos,因此什麼也不懂,就從網上也查了很多資料,都覺得不是最好的方法。最後結合mysql官方資料和網友的資料,最後用rpm方式安裝,並總結給其他人以參考。 首先打開mysql管網,找到“ ...
  • sql資料庫實現分組並取每組的前1(幾)條數據 測試數據準備工作: 根據某一個欄位分組取最大(小)值所在行的數據: 創建表並且插入數據 1、根據Name分組取Val最大的值所在行的數據。 Sql語句代碼如下: 上面的5種方法的sql執行執行結果一樣,結果如下圖: 2、根據Name分組取Val最小的值 ...
  • 前言 LTP語言雲平臺 不支持離線調用; 支持分詞、詞性標註、命名實體識別、依存句法分析、語義角色標註; 不支持自定義詞表,但是你可以先用其他支持自定義分詞的工具(例如中科院的NLPIR)把文本進行分詞,再讓ltp幫你標註 支持C#、Go、Java、JavaScript、Nodejs、PHP、Pyt ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...