<output id="qn6qe"></output>

    1. <output id="qn6qe"><tt id="qn6qe"></tt></output>
    2. <strike id="qn6qe"></strike>

      亚洲 日本 欧洲 欧美 视频,日韩中文字幕有码av,一本一道av中文字幕无码,国产线播放免费人成视频播放,人妻少妇偷人无码视频,日夜啪啪一区二区三区,国产尤物精品自在拍视频首页,久热这里只有精品12

      使用 RediSearch 在 Redis 中進(jìn)行全文檢索

      原文鏈接: 使用 RediSearch 在 Redis 中進(jìn)行全文檢索

      Redis 大家肯定都不陌生了,作為一種快速、高性能的鍵值存儲數(shù)據(jù)庫,廣泛應(yīng)用于緩存、隊(duì)列、會話存儲等方面。

      然而,Redis 在原生狀態(tài)下并不支持全文檢索功能,這使得處理文本數(shù)據(jù)變得相對困難。但是在有一些場景下還需要這樣的功能,有什么好辦法呢?答案就是 RediSearch。

      RediSearch 是 Redis 的一個插件,它為 Redis 數(shù)據(jù)庫添加了全文搜索和查詢功能,使開發(fā)人員能夠在 Redis 中高效地執(zhí)行全文檢索操作。

      它基于 Redis Module API 構(gòu)建,通過使用自定義的數(shù)據(jù)結(jié)構(gòu)和索引算法,實(shí)現(xiàn)了高效的全文搜索功能。

      安裝

      如果單純用來測試的話,可以直接通過 docker 來啟動;如果是生產(chǎn)環(huán)境,就需要根據(jù)公司的實(shí)際情況來支持了。

      $ docker run -p 6379:6379 redis/redis-stack-server:latest
      

      啟動服務(wù)之后,可以使用 FT.* 命令集來體驗(yàn)搜索功能。

      概覽

      為了使用全文搜索功能,我們必須將文檔存儲在哈希中,使用命令 FT.CREATE 創(chuàng)建索引并使用 FT.SEARCH 做文本搜索。

      這樣說可能會比較懵,看下面的示意圖就明白了:

      現(xiàn)在,讓我們插入兩條文檔:

      redis-cli 'hset post:1 title "hello world" body "this is a cool document"'
      redis-cli 'hset post:2 title "goodbye everybody" body "this is the best document"'
      

      上面命令創(chuàng)建兩個哈希值,分別是 post:1post:2,其中包含的字段是 titlebody

      創(chuàng)建索引

      接下來創(chuàng)建索引:

      FT.CREATE post_index prefix 1 post: SCHEMA title TEXT body text
      

      在這里,我們創(chuàng)建了 post_index 索引,它將索引以 post: 前綴開頭的所有 Redis 哈希鍵。只有 titlebody 字段才會被索引,并且索引立即生效。

      搜索索引

      使用 FT.SEARCH 命令,參數(shù)是索引名稱和需要搜索的關(guān)鍵詞:

      FT.SEARCH post_index "world"
      

      實(shí)時索引

      當(dāng)新增一個文檔時,它會被自動添加到索引:

      redis-cli 'hset post:3 title "really?" body "yeah"'
      

      立即可以被搜索到:

      > ft.search post_index "really"
      1) (integer) 1
      2) "post:3"
      3) 1) "title"
         2) "really?"
         3) "body"
         4) "yeah"
      

      搜索特定字段

      可以選擇要搜索的字段,比如 title

      ft.search post_index "@title:world"
      

      按列表中的任何單詞搜索

      類似于邏輯 OR 操作,比如要查找與 hellogoodbye 匹配的所有文檔:

      ft.search post_index "hello|goodbye"
      

      搜索結(jié)果分頁

      和 SQL 是一樣的,使用 LIMIT 關(guān)鍵詞,比如:

      ft.search post_index "world" LIMIT 10, 5
      

      反向搜索

      在搜索關(guān)鍵詞前使用 - 來排除結(jié)果中包含該字段的信息:

      ft.search post_index "-foo"
      

      部分搜索

      還可以使用 * 只搜索單詞的一部分,比如要查找以 good 開頭的單詞的所有文檔:

      ft.search post_index "good*"
      

      需要注意的是,這樣做僅限于前綴,比如關(guān)鍵詞是這樣的話 *good,是不支持的。

      模糊匹配

      這個功能很強(qiáng)大,它是一種近似的搜索手段,使用 %

      假設(shè)你把想要查找的單詞寫錯了,把 world 寫成了 wold,它依然能查出來,比如:

      ft.search post_index "%wold%"
      

      總結(jié)

      最近在工作中遇到了一個問題,因?yàn)閿?shù)據(jù)都存儲在了 Redis 中,而且大部分功能都可以滿足。但其中有一個接口需要模糊查詢,這在 Redis 原生方法中是不容易的。

      所以查找了一些資料,了解到 RediSearch,使用一下還是挺方便的,并且完美地解決了我的問題。也把這篇文章分享給大家,希望對大家有幫助。

      以上就是本文的全部內(nèi)容,如果覺得還不錯的話歡迎點(diǎn)贊轉(zhuǎn)發(fā)關(guān)注,感謝支持。


      參考文章:

      推薦閱讀:

      posted @ 2023-08-04 19:52  yongxinz  閱讀(1265)  評論(0)    收藏  舉報
      主站蜘蛛池模板: 国产黄色一区二区三区四区| 中文字幕在线视频不卡一区二区| 99精品视频在线观看婷婷| 内射干少妇亚洲69xxx| 国产成人MV视频在线观看| 国产精品自拍自在线播放| 欧美 亚洲 日韩 在线综合| 日本偷拍自影像视频久久| 国产日韩AV免费无码一区二区三区| 一区二区免费高清观看国产丝瓜| 国产在线精品一区二区三区| 尚义县| 欧美综合天天夜夜久久| 成人国产精品三上悠亚久久| 亚洲精品在线二区三区| 国产精品免费久久久免费| 亚洲av午夜福利大精品| 日韩av综合免费在线| 99精品国产兔费观看久久99 | 337p粉嫩大胆噜噜噜| 精品一区二区三区免费视频| 亚洲国产精品久久久久婷婷图片| 亚洲精品色国语对白在线| 鸡东县| 国产中文字幕在线精品| 国产三级精品三级在线观看| 亚洲天堂久久一区av| 久久人与动人物a级毛片| 国产精品午夜福利视频234区 | 蜜臀av一区二区三区不卡| 日本熟妇色xxxxx| 久青草视频在线免费观看| 国产综合久久99久久| 久久精品国产亚洲AV麻| 精品久久久bbbb人妻| 天堂网亚洲综合在线| 四虎女优在线视频免费看| 亚洲欧洲一区二区精品| 国产精品自在线拍国产手机版| 好男人日本社区www| 国产11一12周岁女毛片|