麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數據庫 > Redis > 正文

Redis中實現查找某個值的范圍

2020-03-17 12:42:15
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了Redis中實現查找某個值的范圍,本文的題引來了Redis作者Salvatore Sanfilippo(@antirez)的回答,比較經典,需要的朋友可以參考下
 

本文來自Redis在Google Group上的一個問題,有一位同學發貼求助,說要解決如下的一個問題:他有一個IP范圍對應地址的列表,現在需要給出一個IP的情況下,迅速的查找到這個IP在哪個范圍,也就是要判斷此IP的所有地。這個問題引來了Redis作者Salvatore Sanfilippo(@antirez)的回答。解答如下:

例如有下面兩個范圍,10-20和30-40

復制代碼代碼如下:

A_start 10, A_end 20
B_start 30, B_end 40

我們將這兩個范圍的起始位置存在Redis的Sorted Sets數據結構中,基本范圍起始值作為score,范圍名加start和end為其value值:

 

 

復制代碼代碼如下:

redis 127.0.0.1:6379> zadd ranges 10 A_start
(integer) 1
redis 127.0.0.1:6379> zadd ranges 20 A_end
(integer) 1
redis 127.0.0.1:6379> zadd ranges 30 B_start
(integer) 1
redis 127.0.0.1:6379> zadd ranges 40 B_end
(integer) 1

 

這樣數據在插入Sorted Sets后,相當于是將這些起始位置按順序排列好了。

現在我需要查找15這個值在哪一個范圍中,只需要進行如下的zrangbyscore查找:

復制代碼代碼如下:

redis 127.0.0.1:6379> zrangebyscore ranges (15 +inf LIMIT 0 1 
1) "A_end"

這個命令的意思是在Sorted Sets中查找大于15的第一個值。(+inf在Redis中表示正無窮大,15前面的括號表示>15而非>=15)

 

查找的結果是A_end,由于所有值是按順序排列的,所以可以判定15是在A_start到A_end區間上,也就是說15是在A這個范圍里。至此大功告成。

當然,如果你查找到的是一個start,比如咱們用25,執行下面的命令

復制代碼代碼如下:

redis 127.0.0.1:6379> zrangebyscore ranges (25 +inf LIMIT 0 1 
1) "B_start"

返回結果表明其下一個節點是一個start節點,也就是說25這個值不處在任何start和end之間,不屬于任何范圍。

 

當然,這個例子僅適用于類似上面的IP范圍查找的案例,因為這些值范圍之間沒有重合。如果是有重合的情況,這個問題本身也就變成了一個一對多的問題。好吧,如果真的是有重合的范圍,我們又當如何解決呢?歡迎讀者同學你來挑戰。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 久久精品综合视频 | 99精品国产小情侣高潮露脸在线 | 国产激情网 | 久久激情小视频 | 一夜新娘第三季免费观看 | av日韩在线免费观看 | 欧美日本一区二区 | 欧美亚洲国产成人 | 久久久久亚洲精品 | 久久视频精品 | 色七七久久影院 | 全黄裸片武则天艳史 | 91精品国产91久久久久久丝袜 | 外国一级黄色片 | 在线成人精品视频 | 九九热在线免费观看视频 | 欧美日韩一区,二区,三区,久久精品 | 91福利社在线 | 久久精品国产清自在天天线 | 竹内纱里奈和大战黑人 | 久久综合综合 | 日日噜噜噜噜久久久精品毛片 | 午夜在线小视频 | 91精品国产一区二区三区四区在线 | av手机免费在线观看 | 成人在线视频网 | 九九福利视频 | 日韩欧美色综合 | 激情视频导航 | 亚洲精品动漫在线观看 | 曰本三级日本三级日本三级 | 欧美一级黄 | 在线天堂资源 | 素人视频在线观看免费 | 久草在线视频新 | 欧美日韩手机在线观看 | 在线成人看片 | 国产成人精品免费视频大全最热 | 国产成人在线观看免费 | 成人在线激情视频 | 亚洲国产网址 |