成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

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

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

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

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

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

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

安裝

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

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

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

概覽

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

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

圖片圖片

現(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)建兩個(gè)哈希值,分別是 post:1 和 post:2,其中包含的字段是 title 和 body。

創(chuàng)建索引

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

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

圖片圖片

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

搜索索引

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

FT.SEARCH post_index "world"

圖片圖片

實(shí)時(shí)索引

當(dāng)新增一個(gè)文檔時(shí),它會(huì)被自動(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 操作,比如要查找與 hello 或 goodbye 匹配的所有文檔:

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,是不支持的。

模糊匹配

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

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

ft.search post_index "%wold%"

總結(jié)

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

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

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

參考文章:

  • https://github.com/RediSearch
  • https://medium.com/datadenys/full-text-search-in-redis-using-redisearch-31df0deb4f3e

責(zé)任編輯:武曉燕 來源: AlwaysBeta
相關(guān)推薦

2010-05-04 12:18:43

Oracle Text

2023-10-18 18:31:04

SQL查詢數(shù)據(jù)

2021-08-27 14:36:01

主題建模BerTopic

2024-05-06 13:34:28

WireGoogleGo

2020-06-30 08:23:00

JavaScript開發(fā)技術(shù)

2019-04-18 09:15:05

DaskPython計(jì)算

2020-03-07 18:00:17

logzeroPython日志記錄

2009-06-22 10:29:11

集成測(cè)試Spring

2011-08-01 10:41:59

Xcode 條件編譯

2009-12-28 13:59:12

ADO調(diào)用存儲(chǔ)過程

2021-03-24 09:30:02

Jupyter not單元測(cè)試代碼

2010-07-09 10:36:22

SQL Server

2010-07-16 15:42:32

SQL Server

2025-05-26 04:10:00

2011-04-22 10:40:52

SQL ServerWord檢索

2009-03-03 09:00:57

Silverlight數(shù)據(jù)驗(yàn)證UI控件

2020-08-11 13:00:34

GNU bcLinuxShell

2010-11-10 14:18:15

SQL SERVER全

2010-10-20 10:55:54

SQL Server全

2009-07-06 18:18:41

SQL Server全
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 亚洲精品电影网在线观看 | 国产免费人成xvideos视频 | 国产精品久久久久久久7电影 | 国产99视频精品免视看9 | 亚洲精品中文字幕 | 亚洲成人av在线 | 亚洲视频二区 | 成人国产精品久久久 | 成人一区av偷拍 | 国产一区二区在线91 | 成人精品鲁一区一区二区 | 欧美激情综合色综合啪啪五月 | 中文字幕一区二区三 | 日韩三区在线 | 成人羞羞国产免费视频 | 天堂免费看片 | 午夜a v电影 | 四虎影音 | 国产成人一区二区三区久久久 | 成人精品一区二区 | 91精品久久久 | 精品国产欧美 | 最新av中文字幕 | 日韩精品一区二区三区中文字幕 | 欧美最猛黑人xxxⅹ 粉嫩一区二区三区四区公司1 | 毛片免费看 | 精品成人免费一区二区在线播放 | 91爱爱·com | 国产视频福利 | 欧美黑人体内she精在线观看 | 91精品一区二区三区久久久久 | 精品亚洲永久免费精品 | av激情影院 | 亚洲欧洲成人av每日更新 | 久久精品小视频 | 欧美精品一区二区免费视频 | 亚洲一区视频 | 国产一二三区在线 | 嫩草一区二区三区 | 久久人人爽人人爽人人片av免费 | 亚洲精品99|