NoSQL数据库Redis使用命令简介
NoSQL 數據庫Redis使用命令簡介
NOSQL數據庫可以按照它們的數據模型分成4類:
1.鍵-值對存儲庫(Key-Value)
redis……
2.BigTable實現(BigTable-implementations)
HBase
3.文檔庫(Document-stores)
mongo DB
4.圖形數據庫(Graph Database)
代表: Neo4j
Redis 操作簡介
服務啟動
redis服務啟動命令: redis-server /usr/local/etc/redis.conf
redis服務啟動后,可以使用redis 客戶端操作訪問redis了: redis-cli
配置查看
查看配置項命令: CONFIG GET
在客戶端命令模式下,輸入config get * 可以看到redis服務所有的配置。
redis庫
redis服務缺省有16個庫,從db0到db15,使用select 可以選擇指定的庫。
redis key
Redis的key和支持的數據類型及其操作
redis本質上一個key-value db,所以我們首先來看看他的key.首先key也是字符串類型,但是key中不能包括邊界字符
由于key不是binary safe的字符串,所以像”my key”和”mykey\n”這樣包含空格和換行的key是不允許的
順便說一下在redis內部并不限制使用binary字符,這是redis協議限制的。”\r\n”在協議格式中會作為特殊字符。
redis 1.2以后的協議中部分命令已經開始使用新的協議格式了(比如MSET)。
關于key的一個格式約定介紹下,object-type:id:field。比如user:1000:password,blog:xxidxx:title
還有key的長度最好不要太長。道理很明顯占內存啊,而且查找時候相對短key也更慢。不過也推薦過短的key,
比如u:1000:pwd,這樣的。顯然沒上面的user:1000:password可讀性好。
key相關操作命令
下面介紹下key相關的命令
1 DEL key 該命令用于在 key 存在是刪除 key。
2 DUMP key 序列化給定 key ,并返回被序列化的值。
3 EXISTS key 檢查給定 key 是否存在。
4 EXPIRE key seconds 為給定 key 設置過期時間。
5 EXPIREAT key timestamp EXPIREAT 的作用和 EXPIRE 類似,都用于為 key 設置過期時間。 不同在于 EXPIREAT 命令接受的時間參數是 UNIX 時間戳(unix timestamp)。
6 PEXPIRE key milliseconds 設置 key 的過期時間億以毫秒計。
7 PEXPIREAT key milliseconds-timestamp 設置 key 過期時間的時間戳(unix timestamp) 以毫秒計
8 KEYS pattern 查找所有符合給定模式( pattern)的 key 。
9 MOVE key db 將當前數據庫的 key 移動到給定的數據庫 db 當中。
10 PERSIST key 移除 key 的過期時間,key 將持久保持。
11 PTTL key 以毫秒為單位返回 key 的剩余的過期時間。
12 TTL key 以秒為單位,返回給定 key 的剩余生存時間(TTL, time to live)。
13 RANDOMKEY 從當前數據庫中隨機返回一個 key 。
14 RENAME key newkey 修改 key 的名稱
15 RENAMENX key newkey 僅當 newkey 不存在時,將 key 改名為 newkey 。
16 TYPE key 返回 key 所儲存的值的類型。
del key1 key2 ….keyN 刪除給定key,返回刪除key的數目,0表示給定key都不存在
type key 返回給定key的value類型。返回 none 表示不存在key,string字符類型,list 鏈表類型 set 無序集合類型…
dbsize 返回當前數據庫的key數量
select db-index 通過索引選擇數據庫,默認連接的數據庫所有是0,默認數據庫數是16個。返回1表示成功,0失敗
rename oldkey newkey 原子的重命名一個key,如果newkey存在,將會被覆蓋,返回1表示成功,0失敗。可能是oldkey不存在或者和newkey相同
renamenx oldkey newkey 同上,但是如果newkey存在返回失敗
expire key seconds 為key指定過期時間,單位是秒。返回1成功,0表示key已經設置過過期時間或者不存在
ttl key 返回設置過過期時間的key的剩余過期秒數 -1表示key不存在或者沒有設置過過期時間
move key db-index 將key從當前數據庫移動到指定數據庫。返回1成功。0 如果key不存在,或者已經在指定數據庫中
redis> keys a* 1) "abc" 2) "acc" redis> move acc 1 (integer) 1flushdb 刪除 當前數據庫中所有key,此方法不會失敗。慎用
flushall 刪除 所有數據庫中的所有key,此方法不會失敗。更加慎用
Redis支持的數據類型及其操作
數據類型
Redis支持五種類型的數據結構:
- 字符串 (String)
- 有序集合 (ZSet)
- 集合 (Set)
- 哈希 (Hash)
- 列表 (List)
String(字符串)
string是redis最基本的類型,string類型是二進制安全的。意思是redis的string可以包含任何數據。
比如jpg圖片或者序列化的對象 。string類型是Redis最基本的數據類型,一個鍵最大能存儲512MB。
Hash(哈希)
每個 hash 可以存儲 2^32 - 1 鍵值對(40多億)。在Redis里,hash 是一個string類型的field和value的映射表,hash特別適合用于存儲對象。
所以,redis的hash對應了java、C#等語言里的map。
List(列表)
Redis 的 list 類型其實就是一個每個子元素都是string類型的雙向鏈表。你可以將 元素添加到列表的頭和尾。
set(集合)
Redis的set是string類型的無序集合。set的是通過hash table實現的,所以添加,刪除,查找的復雜度都是O(1)。
zset(sorted set:有序集合)
Redis zset 和 set 一樣也是string類型元素的集合,且不允許重復的成員。不同的是每個元素都會關聯一個double類型的score。
redis正是通過分數來為集合中的成員進行從小到大的排序。zset的成員是唯一的,但分數(score)卻可以重復。
string操作
1 SET key value 設置指定 key 的值 2 GET key 獲取指定 key 的值。 3 GETRANGE key start end 返回 key 中字符串值的子字符 4 GETSET key value 將給定 key 的值設為 value ,并返回 key 的舊值(old value)。 5 GETBIT key offset 對 key 所儲存的字符串值,獲取指定偏移量上的位(bit)。 6 MGET key1 [key2..] 獲取所有(一個或多個)給定 key 的值。 7 SETBIT key offset value 對 key 所儲存的字符串值,設置或清除指定偏移量上的位(bit)。 8 SETEX key seconds value 將值 value 關聯到 key ,并將 key 的過期時間設為 seconds (以秒為單位)。 9 SETNX key value 只有在 key 不存在時設置 key 的值。 10 SETRANGE key offset value 用 value 參數覆寫給定 key 所儲存的字符串值,從偏移量 offset 開始。 11 STRLEN key 返回 key 所儲存的字符串值的長度。 12 MSET key value [key value ...] 同時設置一個或多個 key-value 對。 13 MSETNX key value [key value ...] 同時設置一個或多個 key-value 對,當且僅當所有給定 key 都不存在。 14 PSETEX key milliseconds value 這個命令和 SETEX 命令相似,但它以毫秒為單位設置 key 的生存時間,而不是像 SETEX 命令那樣,以秒為單位。 15 INCR key 將 key 中儲存的數字值增一。 16 INCRBY key increment 將 key 所儲存的值加上給定的增量值(increment) 。 17 INCRBYFLOAT key increment 將 key 所儲存的值加上給定的浮點增量值(increment) 。 18 DECR key 將 key 中儲存的數字值減一。 19 DECRBY key decrement key 所儲存的值減去給定的減量值(decrement) 。 20 APPEND key value 如果 key 已經存在并且是一個字符串, APPEND 命令將 value 追加到 key 原來的值的末尾。INCR*和DECR*操作: 對整型值進行處理加減的操作。
127.0.0.1:6379> get abc "abc" 127.0.0.1:6379> INCR abc (error) ERR value is not an integer or out of range 127.0.0.1:6379> TYPE abc string 127.0.0.1:6379> set intval 2 OK 127.0.0.1:6379> type intval string 127.0.0.1:6379> INCR intval (integer) 3 127.0.0.1:6379> INCRBYFLOAT intval 0.15 "3.15"Hash操作
Redis hash 命令以H開頭,代表Hash。
下表列出了 redis hash 基本的相關命令:
序號 命令及描述
1 HDEL key field2 [field2] 刪除一個或多個哈希表字段
2 HEXISTS key field 查看哈希表 key 中,指定的字段是否存在。
3 HGET key field 獲取存儲在哈希表中指定字段的值
4 HGETALL key 獲取在哈希表中指定 key 的所有字段和值
5 HINCRBY key field increment 為哈希表 key 中的指定字段的整數值加上增量 increment 。
6 HINCRBYFLOAT key field increment 為哈希表 key 中的指定字段的浮點數值加上增量 increment 。
7 HKEYS key 獲取所有哈希表中的字段
8 HLEN key 獲取哈希表中字段的數量
9 HMGET key field1 [field2] 獲取所有給定字段的值
10 HMSET key field1 value1 [field2 value2 ] 同時將多個 field-value (域-值)對設置到哈希表 key 中。
11 HSET key field value 將哈希表 key 中的字段 field 的值設為 value 。
12 HSETNX key field value 只有在字段 field 不存在時,設置哈希表字段的值。
13 HVALS key 獲取哈希表中所有值
14 HSCAN key cursor [MATCH pattern] [COUNT count] 迭代哈希表中的鍵值對。
List
Redis列表是簡單的字符串列表,按照插入順序排序。你可以添加一個元素導列表的頭部(左邊)或者尾部(右邊).
一個列表最多可以包含 2^32 - 1 個元素 (4294967295, 每個列表超過40億個元素)。
Redis的列表操作命令大多以L開頭,代表List。
列表命令
下表列出了列表相關的基本命令:
B – Block, L – first, R – last
序號 命令及描述
1 BLPOP key1 [key2 ] timeout 移出并獲取列表的第一個元素, 如果列表沒有元素會阻塞(block)列表直到等待超時或發現可彈出元素為止。
2 BRPOP key1 [key2 ] timeout 移出并獲取列表的最后一個元素, 如果列表沒有元素會阻塞列表直到等待超時或發現可彈出元素為止。
3 BRPOPLPUSH source destination timeout 從列表中彈出一個值,將彈出的元素插入到另外一個列表中并返回它; 如果列表沒有元素會阻塞列表直到等待超時或發現可彈出元素為止。
4 LINDEX key index 通過索引獲取列表中的元素
5 LINSERT key BEFORE|AFTER pivot value 在列表的元素前或者后插入元素
6 LLEN key 獲取列表長度
7 LPOP key 移出并獲取列表的第一個元素
8 LPUSH key value1 [value2] 將一個或多個值插入到列表頭部
9 LPUSHX key value 將一個或多個值插入到已存在的列表頭部
10 LRANGE key start stop 獲取列表指定范圍內的元素
11 LREM key count value 移除列表元素
12 LSET key index value 通過索引設置列表元素的值
13 LTRIM key start stop 對一個列表進行修剪(trim),就是說,讓列表只保留指定區間內的元素,不在指定區間之內的元素都將被刪除。
14 RPOP key 移除并獲取列表最后一個元素
15 RPOPLPUSH source destination 移除列表的最后一個元素,并將該元素添加到另一個列表并返回
16 RPUSH key value1 [value2] 在列表中添加一個或多個值
17 RPUSHX key value 為已存在的列表添加值
示例:
127.0.0.1:6379[4]> LPUSH product:book redis (integer) 1 127.0.0.1:6379[4]> LPUSH product:book mongodb (integer) 2 127.0.0.1:6379[4]> LPUSH product:book mongodb in action (integer) 5 127.0.0.1:6379[4]> LPUSH product:book "mongodb in action" (integer) 6 // 長度 127.0.0.1:6379[4]> LLEN product:book (integer) 6 // index 從0開始,指定的大于列表其長度時,獲取到最后的元素。 127.0.0.1:6379[4]> LRANGE product:book 0 7 1) "mongodb in action" 2) "action" 3) "in" 4) "mongodb" 5) "mongodb" 6) "redis"127.0.0.1:6379[4]> RPUSH product:book "spring in action" (integer) 7127.0.0.1:6379[4]> LRANGE product:book 0 10 1) "mongodb in action" 2) "action" 3) "in" 4) "mongodb" 5) "mongodb" 6) "redis" 7) "spring in action" // index: start from 0. 127.0.0.1:6379[4]> lset product:book 3 "what" OK127.0.0.1:6379[4]> LRANGE product:book 0 10 1) "mongodb in action" 2) "action" 3) "in" 4) "what" 5) "mongodb" 6) "redis" 7) "spring in action" // 127.0.0.1:6379[4]> RPOP product:book "spring in action"127.0.0.1:6379[4]> LRANGE product:book 0 10 1) "mongodb in action" 2) "action" 3) "in" 4) "what" 5) "mongodb" 6) "redis"127.0.0.1:6379[4]> LPOP product:book "mongodb in action" 127.0.0.1:6379[4]> LRANGE product:book 0 10 1) "action" 2) "in" 3) "what" 4) "mongodb" 5) "redis" 127.0.0.1:6379[4]> 127.0.0.1:6379[4]> LINDEX product:book 1 "in" 127.0.0.1:6379[4]> LRANGE product:book 0 10 1) "action" 2) "in" 3) "what" 4) "mongodb" 5) "redis" // 移除元素 -- value必須指定正確,否則,不會移除。 127.0.0.1:6379[4]> lrem product:book 2 "what" (integer) 1 127.0.0.1:6379[4]> LRANGE product:book 0 10 1) "action" 2) "in" 3) "mongodb" 4) "redis"Redis 集合(Set)
Redis的Set是string類型的無序集合。集合成員是唯一的,這就意味著集合中不能出現重復的數據。
Redis中集合是通過哈希表實現的,所以添加,刪除,查找的復雜度都是O(1)。
集合中最大的成員數為 2^32 - 1 (4294967295, 每個集合可存儲40多億個成員)。
Redis 集合命令
下表列出了 Redis 集合基本命令:集合的命令以S開頭,表示Set.
序號 命令及描述
1 SADD key member1 [member2] 向集合添加一個或多個成員
2 SCARD key 獲取集合的成員數
3 SDIFF key1 [key2] 返回給定所有集合的差集
4 SDIFFSTORE destination key1 [key2] 返回給定所有集合的差集并存儲在 destination 中
5 SINTER key1 [key2] 返回給定所有集合的交集
6 SINTERSTORE destination key1 [key2] 返回給定所有集合的交集并存儲在 destination 中
7 SISMEMBER key member 判斷 member 元素是否是集合 key 的成員
8 SMEMBERS key 返回集合中的所有成員
9 SMOVE source destination member 將 member 元素從 source 集合移動到 destination 集合
10 SPOP key 移除并返回集合中的一個隨機元素
11 SRANDMEMBER key [count] 返回集合中一個或多個隨機數
12 SREM key member1 [member2] 移除集合中一個或多個成員
13 SUNION key1 [key2] 返回所有給定集合的并集
14 SUNIONSTORE destination key1 [key2] 所有給定集合的并集存儲在 destination 集合中
15 SSCAN key cursor [MATCH pattern] [COUNT count] 迭代集合中的元素
示例:
127.0.0.1:6379[4]> select 5 OK 127.0.0.1:6379[5]> dbsize (integer) 0 127.0.0.1:6379[5]> sadd product:set iphone (integer) 1 127.0.0.1:6379[5]> dbsize (integer) 1 127.0.0.1:6379[5]> sadd product:set nexus lumia (integer) 2 127.0.0.1:6379[5]> dbsize (integer) 1 127.0.0.1:6379[5]> SMEMBERS product:set 1) "iphone" 2) "lumia" 3) "nexus"127.0.0.1:6379[5]> sadd book:set "Spring in action" "redis in action" (integer) 2 127.0.0.1:6379[5]> SMEMBERS book:set 1) "redis in action" 2) "Spring in action" 127.0.0.1:6379[5]> SCARD (error) ERR wrong number of arguments for 'scard' command 127.0.0.1:6379[5]> SCARD product (integer) 0 127.0.0.1:6379[5]> SCARD product:book (integer) 0 127.0.0.1:6379[5]> SCARD product:set (integer) 3 127.0.0.1:6379[5]> SCARD book:set (integer) 2127.0.0.1:6379[5]> SUNION book:set product:set 1) "iphone" 2) "lumia" 3) "Spring in action" 4) "redis in action" 5) "nexus" 127.0.0.1:6379[5]> Sinter book:set product:set (empty list or set) 127.0.0.1:6379[5]> sadd book:set iphone (integer) 1 127.0.0.1:6379[5]> Sinter book:set product:set 1) "iphone" 127.0.0.1:6379[5]> SDIFF book:set product:set 1) "Spring in action" 2) "redis in action" 127.0.0.1:6379[5]> SDIFF product:set book:set 1) "nexus" 2) "lumia" 127.0.0.1:6379[5]> SDIFFSTORE product:other product:set book:set (integer) 2 127.0.0.1:6379[5]> SMEMBERS product:other 1) "nexus" 2) "lumia" 127.0.0.1:6379[5]> srem product:other nexus (integer) 1 127.0.0.1:6379[5]> SMEMBERS product:other 1) "lumia" 127.0.0.1:6379[5]> smembers book:set 1) "iphone" 2) "redis in action" 3) "Spring in action" 127.0.0.1:6379[5]> sadd book:set "redis in action" (integer) 0 127.0.0.1:6379[5]> smembers book:set 1) "iphone" 2) "redis in action" 3) "Spring in action" 127.0.0.1:6379[5]> smembers book:set 1) "iphone" 2) "redis in action" 3) "Spring in action"Redis 有序集合(sorted set)
Redis 有序集合和集合一樣也是string類型元素的集合,且不允許重復的成員。 集合是通過哈希表實現的,所以添加,刪除,查找的復雜度都是O(1)。 集合中最大的成員數為 2^32 - 1 (4294967295, 每個集合可存儲40多億個成員)。
不同的是每個元素都會關聯一個double類型的分數。redis正是通過分數來為集合中的成員進行從小到大的排序。有序集合的成員是唯一的,但分數(score)卻可以重復。
Redis 有序集合命令
下表列出了 redis 有序集合的基本命令,命令以Z開頭:
序號 命令及描述
1 ZADD key score1 member1 [score2 member2] 向有序集合添加一個或多個成員,或者更新已存在成員的分數
2 ZCARD key 獲取有序集合的成員數
3 ZCOUNT key min max 計算在有序集合中指定區間分數的成員數
4 ZINCRBY key increment member 有序集合中對指定成員的分數加上增量 increment
5 ZINTERSTORE destination numkeys key [key …] 計算給定的一個或多個有序集的交集并將結果集存儲在新的有序集合 key 中
6 ZLEXCOUNT key min max 在有序集合中計算指定字典區間內成員數量
7 ZRANGE key start stop [WITHSCORES] 通過索引區間返回有序集合成指定區間內的成員
8 ZRANGEBYLEX key min max [LIMIT offset count] 通過字典區間返回有序集合的成員
9 ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT] 通過分數返回有序集合指定區間內的成員
10 ZRANK key member 返回有序集合中指定成員的索引
11 ZREM key member [member …] 移除有序集合中的一個或多個成員
12 ZREMRANGEBYLEX key min max 移除有序集合中給定的字典區間的所有成員
13 ZREMRANGEBYRANK key start stop 移除有序集合中給定的排名區間的所有成員
14 ZREMRANGEBYSCORE key min max 移除有序集合中給定的分數區間的所有成員
15 ZREVRANGE key start stop [WITHSCORES] 返回有序集中指定區間內的成員,通過索引,分數從高到底
16 ZREVRANGEBYSCORE key max min [WITHSCORES] 返回有序集中指定分數區間內的成員,分數從高到低排序
17 ZREVRANK key member 返回有序集合中指定成員的排名,有序集成員按分數值遞減(從大到小)排序
18 ZSCORE key member 返回有序集中,成員的分數值
19 ZUNIONSTORE destination numkeys key [key …] 計算給定的一個或多個有序集的并集,并存儲在新的 key 中
20 ZSCAN key cursor [MATCH pattern] [COUNT count] 迭代有序集合中的元素(包括元素成員和元素分值)
示例:
127.0.0.1:6379[6]> zadd product:major:lesson 1 java (integer) 1 127.0.0.1:6379[6]> dbsize (integer) 1 127.0.0.1:6379[6]> zadd product:major:lesson 2 mongodb (integer) 1 127.0.0.1:6379[6]> zadd product:major:lesson 3 redis (integer) 1 127.0.0.1:6379[6]> zadd product:major:lesson 4 mysql (integer) 1 127.0.0.1:6379[6]> dbsize (integer) 1127.0.0.1:6379[6]> ZRANGE product:major:lesson 0 10 1) "java" 2) "mongodb" 3) "redis" 4) "mysql"127.0.0.1:6379[6]> ZRANGE product:major:lesson 0 10 withscores 1) "java" 2) "1" 3) "mongodb" 4) "2" 5) "redis" 6) "3" 7) "mysql" 8) "4" // 127.0.0.1:6379[6]> ZRANGEBYSCOre product:major:lesson 1 4 1) "java" 2) "mongodb" 3) "redis" 4) "mysql" 127.0.0.1:6379[6]> ZRANGEBYSCOre product:major:lesson 2 4 1) "mongodb" 2) "redis" 3) "mysql"127.0.0.1:6379[6]> ZCARD product:major:lesson (integer) 4127.0.0.1:6379[6]> ZCARD product:major:lesson (integer) 4 127.0.0.1:6379[6]> ZCOUNT product:major:lesson 0 100 (integer) 4 127.0.0.1:6379[6]> ZCOUNT product:major:lesson 2 10 (integer) 3 // 返回zset指定member的score 127.0.0.1:6379[6]> ZSCORE product:major:lesson mysql "4" // 有序集合中指定成員的索引 -- start from 0. 127.0.0.1:6379[6]> ZRANK product:major:lesson mysql (integer) 3 // ZREVRange 127.0.0.1:6379[6]> ZREVRange product:major:lesson 2 4 1) "mongodb" 2) "java" 127.0.0.1:6379[6]> ZREVRange product:major:lesson 2 3 1) "mongodb" 2) "java" 127.0.0.1:6379[6]> ZREVRange product:major:lesson 0 1 1) "mysql" 2) "redis"telnet方式連接redis
telnet> open 127.0.0.1 6379 Trying 127.0.0.1... Connected to localhost. Escape character is '^]'. dbdize -ERR unknown command 'dbdize' dbsize :5 keys t* *3 $5 testb $5 testa $5 testckeys * *5 $5 testb $5 testa $6 intval $3 abc $5 testc shutdown Connection closed by foreign host.關閉服務
使用shutdown命令來關閉服務。
#關閉指定端口的redis-server $redis-cli -p 6380 shutdown或者在telnet連接后,輸入shutdown命令關閉服務。
總結
以上是生活随笔為你收集整理的NoSQL数据库Redis使用命令简介的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 微笑的眼泪
- 下一篇: SQL:find duplicate r