wordpress會員查看發(fā)布插件上海網(wǎng)站快速排名優(yōu)化
目錄
Redis 常用命令集
string類型
hash類型
list類型
?set類型
zset類型?
bitmap 類型
geo 類型
GEOADD (添加地理位置的坐標(biāo))
GEOPOS (獲取地理位置的坐標(biāo))
GEODIST (計算兩個位置之間的距離)
GEOHASH (返回一個或多個位置對象的 geohash 值)
GEORADIUS (根據(jù)用戶給定的經(jīng)緯度坐標(biāo)來獲取指定范圍內(nèi)的地理位置集合)
GEORADIUSBYMEMBER (在距離給定元素 radius 距離的圓中查找元素)
Redis客戶端命令對應(yīng)的RedisTemplate中的方法列表
Redis 常用命令集
string類型
普通的字符串類型,表示一個簡單值.
下表列出了常用的 redis 字符串命令:
序號 | 命令 | 描述 |
---|---|---|
1 | set key value | 設(shè)置指定 key 的值 |
2 | ?get key | 獲取指定 key 的值。 |
3 | ?getrange key start end | 返回 key 中字符串值的子字符 |
4 | ?getset key value | 將給定 key 的值設(shè)為 value ,并返回 key 的舊值(old value)。 |
5 | ?getbit key offset | 對 key 所儲存的字符串值,獲取指定偏移量上的位(bit)。 |
6 | ?mget key1 [key2..] | 獲取所有(一個或多個)給定 key 的值。 |
7 | ?setbit key offset value | 對 key 所儲存的字符串值,設(shè)置或清除指定偏移量上的位(bit)。 |
8 | ?setex key seconds value | 將值 value 關(guān)聯(lián)到 key ,并將 key 的過期時間設(shè)為 seconds (以秒為單位)。 |
9 | ?setnx key value | 只有在 key 不存在時設(shè)置 key 的值。 |
10 | ?setrange key offset value | 用 value 參數(shù)覆寫給定 key 所儲存的字符串值,從偏移量 offset 開始。 |
11 | ?strlen key | 返回 key 所儲存的字符串值的長度。 |
12 | ?mset key value [key value ...] | 同時設(shè)置一個或多個 key-value 對。 |
13 | ?msetnx key value [key value ...] | 同時設(shè)置一個或多個 key-value 對,當(dāng)且僅當(dāng)所有給定 key 都不存在。 |
14 | ?psetex key milliseconds value | 這個命令和 SETEX 命令相似,但它以毫秒為單位設(shè)置 key 的生存時間,而不是像 SETEX 命令那樣,以秒為單位。 |
15 | incr key | 將 key 中儲存的數(shù)字值增一。 |
16 | incrby key increment | 將 key 所儲存的值加上給定的增量值(increment) 。 |
17 | incrbyfloat key increment | 將 key 所儲存的值加上給定的浮點(diǎn)增量值(increment) 。 |
18 | decr key | 將 key 中儲存的數(shù)字值減一。 |
19 | decrby key decrement | key 所儲存的值減去給定的減量值(decrement) 。 |
20 | append key value | 如果 key 已經(jīng)存在并且是一個字符串, APPEND 命令將 value 追加到 key 原來的值的末尾。 |
21 | ttl key | 可以查詢出當(dāng)前的key還剩余多長時間過期 |
22 | del key [key ...] | 刪除一個key |
23 | expire key? seconds | 設(shè)置一個key的過期時間(秒) |
hash類型
hash類型 / hash對象,其實(shí)就是Map類型,其內(nèi)部又可以有多個鍵值對,可以用于存儲對象
下表列出了 redis hash 基本的相關(guān)命令:
序號 | 命令 | 描述 |
---|---|---|
1 | hdel key field1 [field2] | 刪除一個或多個哈希表字段 |
2 | hexists key field | 查看哈希表 key 中,指定的字段是否存在。 |
3 | hget key field | 獲取存儲在哈希表中指定字段的值 |
4 | hgetall key | 獲取在哈希表中指定 key 的所有字段和值 |
5 | hincrby key field increment | 為哈希表 key 中的指定字段的整數(shù)值加上增量 increment 。 |
6 | hincrbyfloat key field increment | 為哈希表 key 中的指定字段的浮點(diǎn)數(shù)值加上增量 increment 。 |
7 | hkeys key | 獲取所有哈希表中的字段 |
8 | hlen key | 獲取哈希表中字段的數(shù)量 |
9 | hmget key field1 [field2] | 獲取所有給定字段的值 |
10 | hmset key field1 value1 [field2 value2 ] | 同時將多個 field-value (域-值)對設(shè)置到哈希表 key 中。 |
11 | hset key field value | 將哈希表 key 中的字段 field 的值設(shè)為 value 。 |
12 | hsetnx key field value | 只有在字段 field 不存在時,設(shè)置哈希表字段的值。 |
13 | hvals key | 獲取哈希表中所有值 |
14 | hscan key cursor [MATCH pattern] [COUNT count] | 迭代哈希表中的鍵值對。 |
list類型
list類型更多的傾向隊列,能直接操作首尾元素
下表列出了列表相關(guān)的基本命令:
序號 | 命令 | 描述 |
---|---|---|
1 | blpop key1 [key2 ] timeout | 移出并獲取列表的第一個元素, 如果列表沒有元素會阻塞列表直到等待超時或發(fā)現(xiàn)可彈出元素為止。 |
2 | brpop key1 [key2 ] timeout | 移出并獲取列表的最后一個元素, 如果列表沒有元素會阻塞列表直到等待超時或發(fā)現(xiàn)可彈出元素為止。 |
3 | brpoplpush source destination timeout | 從列表中彈出一個值,將彈出的元素插入到另外一個列表中并返回它; 如果列表沒有元素會阻塞列表直到等待超時或發(fā)現(xiàn)可彈出元素為止。 |
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 | 獲取列表指定范圍內(nèi)的元素 |
11 | lrem key count value | 移除列表元素 |
12 | lset key index value | 通過索引設(shè)置列表元素的值 |
13 | ltrim key start stop | 對一個列表進(jìn)行修剪(trim),就是說,讓列表只保留指定區(qū)間內(nèi)的元素,不在指定區(qū)間之內(nèi)的元素都將被刪除。 |
14 | rpop key | 移除并獲取列表最后一個元素 |
15 | rpoplpush source destination | 移除列表的最后一個元素,并將該元素添加到另一個列表并返回 |
16 | rpush key value1 [value2] | 在列表中添加一個或多個值 |
17 | rpushx key value | 為已存在的列表添加值 |
?set類型
跟Java中的set集合性質(zhì)一樣,底層使用哈希表實(shí)現(xiàn)的,存入的元素是無序不可重復(fù)的,我們可以通過Redis提供的命令來取交集,并集,差集
下表列出了 Redis 集合基本命令:
序號 | 命令 | 描述 |
---|---|---|
1 | sadd key member1 [member2] | 向集合添加一個或多個成員 |
2 | scard key | 獲取集合的成員數(shù) |
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 | 移除并返回集合中的一個隨機(jī)元素 |
11 | srandmember key [count] | 返回集合中一個或多個隨機(jī)數(shù) |
12 | srem key member1 [member2] | 移除集合中一個或多個成員 |
13 | sunion key1 [key2] | 返回所有給定集合的并集 |
14 | sunionstore destination key1 [key2] | 所有給定集合的并集存儲在 destination 集合中 |
15 | sscan key cursor [MATCH pattern] [COUNT count] | 迭代集合中的元素 |
zset類型?
Redis 有序集合是通過哈希表實(shí)現(xiàn)的, 每個元素都會關(guān)聯(lián)一個double類型的分?jǐn)?shù), 成員是唯一的, 但分?jǐn)?shù)可以重復(fù).redis 正是通過分?jǐn)?shù)來為集合中的成員從小到大來排序.
下表列出了 redis 有序集合的基本命令:
序號 | 命令 | 描述 |
---|---|---|
1 | zadd key score1 member1 [score2 member2] | 向有序集合添加一個或多個成員,或者更新已存在成員的分?jǐn)?shù) |
2 | zcard key | 獲取有序集合的成員數(shù) |
3 | zcount key min max | 計算在有序集合中指定區(qū)間分?jǐn)?shù)的成員數(shù) |
4 | zincrby key increment member | 有序集合中對指定成員的分?jǐn)?shù)加上增量 increment |
5 | zinterstore destination numkeys key [key ...] [WEIGHTS weight] [AGGREGATE SUM|MIN|MAX]? | 計算給定的一個或多個有序集的交集并將結(jié)果集存儲在新的有序集合 key 中 |
6 | zlexcount key min max | 在有序集合中計算指定字典區(qū)間內(nèi)成員數(shù)量 |
7 | zrange key start stop [WITHSCORES] | 通過索引區(qū)間返回有序集合成指定區(qū)間內(nèi)的成員 |
8 | zrangebylex key min max [LIMIT offset count] | 通過字典區(qū)間返回有序集合的成員 |
9 | ?zrangebyscore key min max [WITHSCORES] [LIMIT] | 通過分?jǐn)?shù)返回有序集合指定區(qū)間內(nèi)的成員 |
10 | zrank key member | 返回有序集合中指定成員的索引 |
11 | zrem key member [member ...] | 移除有序集合中的一個或多個成員 |
12 | zremrangebylex key min max | 移除有序集合中給定的字典區(qū)間的所有成員 |
13 | zremrangebyrank key start stop | 移除有序集合中給定的排名區(qū)間的所有成員 |
14 | zremrangebyscore key min max | 移除有序集合中給定的分?jǐn)?shù)區(qū)間的所有成員 |
15 | zrevrange key start stop [WITHSCORES] | 返回有序集中指定區(qū)間內(nèi)的成員,通過索引,分?jǐn)?shù)從高到底 |
16 | zrevrangebyscore key max min [WITHSCORES] | 返回有序集中指定分?jǐn)?shù)區(qū)間內(nèi)的成員,分?jǐn)?shù)從高到低排序 |
17 | zrevrank key member | 返回有序集合中指定成員的排名,有序集成員按分?jǐn)?shù)值遞減(從大到小)排序 |
18 | zscore key member | 返回有序集中,成員的分?jǐn)?shù)值 |
19 | zunionstore destination numkeys key [key ...] [WEIGHTS weight] [AGGREGATE SUM|MIN|MAX]? | 計算給定的一個或多個有序集的并集,并存儲在新的 key 中 |
20 | zscan key cursor [MATCH pattern] [COUNT count] | 迭代有序集合中的元素(包括元素成員和元素分值) |
?注:
- destination:新的有序集的名稱
- numkeys:需要計算的有序集的數(shù)量
- key:需要計算的有序集的名稱
- WEIGHTS:權(quán)重參數(shù),用于對每個有序集進(jìn)行加權(quán)。默認(rèn)權(quán)重為1。
- AGGREGATE:聚合參數(shù),用于確定計算并集時使用的聚合函數(shù)。默認(rèn)為SUM。
bitmap 類型
Redis 的 Bitmap(位圖)是一種特殊的字符串?dāng)?shù)據(jù)類型,它利用字符串類型鍵(key)來存儲一系列連續(xù)的二進(jìn)制位(bits),每個位可以獨(dú)立地表示一個布爾值(0 或 1)。這種數(shù)據(jù)結(jié)構(gòu)非常適合用于存儲和操作大量二值狀態(tài)的數(shù)據(jù),尤其在需要高效空間利用率和特定位操作場景中表現(xiàn)出色。
下表列出了 redis 位圖的基本命令:
序號 | 命令 | 描述 |
---|---|---|
1 | setbit key offset value | 設(shè)置或清除指定偏移量上的位(bit)。offset ?是從0開始的位索引,value ?可以為 0 或 1。 |
2 | getbit key offset | 返回指定偏移量上的位值。 |
3 | bitcount key [start end] | 計算鍵內(nèi)指定范圍內(nèi)(或整個鍵)為 1 的位的數(shù)量。 |
4 | bitop operation destkey key [key ...] | 對一個或多個鍵執(zhí)行位操作,并將結(jié)果保存到?destkey 。支持的操作包括 AND、OR、XOR、NOT。 |
5 | bitpos key bit [start] [end] | 查找指定鍵內(nèi)第一個值為?bit (0 或 1)的位的偏移量,可指定范圍。 |
geo 類型
獲取某個位置的經(jīng)緯度信息
- 騰訊位置服務(wù) - 立足生態(tài),連接未來
- 坐標(biāo)拾取器 | 高德地圖API
- 拾取坐標(biāo)系統(tǒng)
常用命令
- GEOADD: 用于添加一個或多個地理位置到指定的鍵中。每個位置由其經(jīng)度、緯度和一個關(guān)聯(lián)的成員(如地點(diǎn)名稱)定義。
GEOPOS
: 根據(jù)成員查詢并返回一個或多個地理位置的坐標(biāo)。- GEOHASH: 將地理位置的坐標(biāo)轉(zhuǎn)化為一個唯一的字符串編碼(GeoHash),這有助于快速索引和查詢。
GEODIST
: 計算兩個地理位置之間的距離,可選的距離單位有m(米)、km(千米)、mi(英里)、ft(英尺)。- GEORADIUS: 查詢指定位置周圍的地點(diǎn),基于給定的最大距離(半徑)。
- GEORADIUSBYMEMBER: 類似于GEORADIUS,但不是基于坐標(biāo)而是基于集合中的一個成員來執(zhí)行查詢。
- GEODEL:刪除給定位置上的元素
GEOADD (添加地理位置的坐標(biāo))
說明:
geoadd 用于存儲指定的地理空間位置,可以將一個或多個經(jīng)度(longitude)、緯度(latitude)、位置名稱(member)添加到指定的 key 中
語法:
GEOADD key longitude latitude member [longitude latitude member ...]
參數(shù)說明
- key:要添加點(diǎn)的鍵值。
- longitude:要添加點(diǎn)的經(jīng)度。
- latitude:要添加點(diǎn)的緯度。
- member:要添加點(diǎn)的成員屬性,可以根據(jù)需要進(jìn)行設(shè)置。
GEOPOS (獲取地理位置的坐標(biāo))
說明:
GEOPOS命令用于獲取一個或多個點(diǎn)的經(jīng)緯度坐標(biāo)。
語法:
GEOPOS key member [member ...]
?參數(shù)說明
- key:要獲取點(diǎn)的鍵值。
- member:要獲取點(diǎn)的成員屬性,可以根據(jù)需要進(jìn)行設(shè)置。
GEODIST (計算兩個位置之間的距離)
說明:
GEODIST命令用于計算兩個給定位置之間的距離,以雙精度浮點(diǎn)數(shù)的形式返回。
語法:
GEODIST key member1 member2 [unit]
參數(shù)說明
- key:可以是一個鍵值,但該參數(shù)不是必需的。
- member1:要計算距離的位置1的成員屬性。
- member2:要計算距離的位置2的成員屬性。
- unit:可以指定返回的距離單位,可以是m(米)、km(千米)、mi(英里)或ft(英尺)。
GEOHASH (返回一個或多個位置對象的 geohash 值)
說明:
Redis GEO 使用 GEOHASH 來保存地理位置的坐標(biāo)。GEOHASH? 用于獲取一個或多個位置元素的 GEOHASH 值。
語法:
GEOHASH key member [member ...]
參數(shù)說明
- key:可以是一個鍵值,但該參數(shù)不是必需的。
- member1:要計算距離的位置1的成員屬性。
- member2:要計算距離的位置2的成員屬性。
GEORADIUS (根據(jù)用戶給定的經(jīng)緯度坐標(biāo)來獲取指定范圍內(nèi)的地理位置集合)
說明:
根據(jù)用戶給定的經(jīng)緯度坐標(biāo)來獲取指定范圍內(nèi)的地理位置集合。
語法:
GEORADIUS key longitude latitude radius m|km|ft|mi [WITHCOORD] [WITHDIST] [WITHHASH] [COUNT count] [ASC]
參數(shù)說明
- key:要查找的點(diǎn)的鍵值。
- longitude:要查找的點(diǎn)的經(jīng)度。
- latitude:要查找的點(diǎn)的緯度。
- radius:可以設(shè)置半徑的大小,后面需要指定單位,如m、km、ft或mi。
- [WITHCOORD]:如果需要,可以使用WITHCOORD選項(xiàng)來返回包含距離計算的點(diǎn)的經(jīng)緯度坐標(biāo)。
- [WITHDIST]:如果需要,可以使用WITHDIST選項(xiàng)來返回包含距離計算的點(diǎn)的距離。
- [WITHHASH]:如果需要,可以使用WITHHASH選項(xiàng)來返回包含距離計算的點(diǎn)的哈希值。
- [COUNT count]:如果需要,可以使用COUNT count選項(xiàng)來指定返回的距離計算的點(diǎn)的數(shù)量。
- [ASC]:如果需要,可以使用ASC選項(xiàng)來指定按距離升序排列返回的距離計算的點(diǎn)。
GEORADIUSBYMEMBER (在距離給定元素 radius 距離的圓中查找元素)
說明:
GEORADIUSBYMEMBER命令用于計算給定成員屬性在指定半徑范圍內(nèi)的其他點(diǎn)的距離和坐標(biāo)。
語法:
GEORADIUSBYMEMBER key member radius m|km|ft|mi [WITHCOORD] [WITHDIST] [WITHHASH] [COUNT count] [ASC|DES]
參數(shù)說明
- key:要查找的點(diǎn)的鍵值。
- member:要查找的點(diǎn)的成員屬性。
- radius:可以設(shè)置半徑的大小,后面需要指定單位,如m、km、ft或mi。
- [WITHCOORD]:如果需要,可以使用WITHCOORD選項(xiàng)來返回包含距離計算的點(diǎn)的經(jīng)緯度坐標(biāo)。
- [WITHDIST]:如果需要,可以使用WITHDIST選項(xiàng)來返回包含距離計算的點(diǎn)的距離。
- [WITHHASH]:如果需要,可以使用WITHHASH選項(xiàng)來返回包含距離計算的點(diǎn)的哈希值。
- [COUNT count]:如果需要,可以使用COUNT count選項(xiàng)來指定返回的距離計算的點(diǎn)的數(shù)量。
- [ASC|DES:如果需要,可以使用ASC選項(xiàng)來指定按距離升序排列返回的距離計算的點(diǎn),或者使用DES選項(xiàng)來指定按距離降序排列返回的距離計算的點(diǎn)。
Redis客戶端命令對應(yīng)的RedisTemplate中的方法列表
String結(jié)構(gòu) | |
Redis | RedisTemplate rt |
set key value | rt.opsForValue().set("key","value") |
get key | rt.opsForValue().get("key") |
del key | rt.delete("key") |
strlen key | rt.opsForValue().size("key") |
getset key value | rt.opsForValue().getAndSet("key","value") |
getrange key start end | rt.opsForValue().get("key",start,end) |
append key value | rt.opsForValue().append("key","value") |
Hash結(jié)構(gòu) | |
hmset key field1 value1 field2 value2... | rt.opsForHash().putAll("key",map) //map是一個集合對象 |
hset key field value | rt.opsForHash().put("key","field","value") |
hexists key field | rt.opsForHash().hasKey("key","field") |
hgetall key | rt.opsForHash().entries("key")? //返回Map對象 |
hvals key | rt.opsForHash().values("key") //返回List對象 |
hkeys key | rt.opsForHash().keys("key") //返回List對象 |
hmget key field1 field2... | rt.opsForHash().multiGet("key",keyList) |
hsetnx key field value | rt.opsForHash().putIfAbsent("key","field","value" |
hdel key field1 field2 | rt.opsForHash().delete("key","field1","field2") |
hget key field | rt.opsForHash().get("key","field") |
List結(jié)構(gòu) | |
lpush list node1 node2 node3... | rt.opsForList().leftPush("list","node")? |
rt.opsForList().leftPushAll("list",list) //list是集合對象 | |
rpush list node1 node2 node3... | rt.opsForList().rightPush("list","node")? |
rt.opsForList().rightPushAll("list",list) //list是集合對象 | |
lindex key index | rt.opsForList().index("list", index) |
llen key | rt.opsForList().size("key") |
lpop key | rt.opsForList().leftPop("key") |
rpop key | rt.opsForList().rightPop("key") |
lpushx list node | rt.opsForList().leftPushIfPresent("list","node") |
rpushx list node | rt.opsForList().rightPushIfPresent("list","node") |
lrange list start end | rt.opsForList().range("list",start,end) |
lrem list count value | rt.opsForList().remove("list",count,"value") |
lset key index value | rt.opsForList().set("list",index,"value") |
Set結(jié)構(gòu) | |
sadd key member1 member2... | rt.boundSetOps("key").add("member1","member2",...) |
rt.opsForSet().add("key", set) //set是一個集合對象 | |
scard key | rt.opsForSet().size("key") |
sidff key1 key2 | rt.opsForSet().difference("key1","key2") //返回一個集合對象 |
sinter key1 key2 | rt.opsForSet().intersect("key1","key2")//同上 |
sunion key1 key2 | rt.opsForSet().union("key1","key2")//同上 |
sdiffstore des key1 key2 | rt.opsForSet().differenceAndStore("key1","key2","des") |
sinter des key1 key2 | rt.opsForSet().intersectAndStore("key1","key2","des") |
sunionstore des key1 key2 | rt.opsForSet().unionAndStore("key1","key2","des") |
sismember key member | rt.opsForSet().isMember("key","member") |
smembers key | rt.opsForSet().members("key") |
spop key | rt.opsForSet().pop("key") |
srandmember key count | rt.opsForSet().randomMember("key",count) |
srem key member1 member2... | rt.opsForSet().remove("key","member1","member2",...) |
ZSet 結(jié)構(gòu) | |
zadd key num name | rt.opsForZSet().add(key, value, score) |
zrange key start end | rt.opsForZSet().range(key, start, end) |
zrangebyscore key min max [withscores] | rt.opsForZSet().rangeByScore(key, min, max) |
zrevrange key start end | rt.opsForZSet().reverseRange(key, start, end) |
zrevrangebyscore key max min [withscores] | rt.opsForZSet().reverseRangeByScore(key, min, max) |
zincrby key num name | rt.opsForZSet().incrementScore(key, value, delta) |
zrank key name | rt.opsForZSet().rank(key, value) |
zrevrank key name | rt.opsForZSet().reverseRank(key, value) |
zrem key name | rt.opsForZSet().remove(key, values...) |
zscore key member | rt.opsForZSet().score(key, value) |