欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Redis全文搜索教程之創(chuàng)建索引并關(guān)聯(lián)源數(shù)據(jù)的教程

 更新時(shí)間:2023年12月21日 09:03:20   作者:waynaqua  
RediSearch提供了一種簡(jiǎn)單快速的方法對(duì) hash 或者 json 類型數(shù)據(jù)的任何字段建立二級(jí)索引,然后就可以對(duì)被索引的 hash 或者 json 類型數(shù)據(jù)字段進(jìn)行搜索和聚合操作,這篇文章主要介紹了Redis全文搜索教程之創(chuàng)建索引并關(guān)聯(lián)源數(shù)據(jù),需要的朋友可以參考下

Redis 全文搜索是依賴于 Redis 官方提供的 RediSearch 來實(shí)現(xiàn)的。RediSearch 提供了一種簡(jiǎn)單快速的方法對(duì) hash 或者 json 類型數(shù)據(jù)的任何字段建立二級(jí)索引,然后就可以對(duì)被索引的 hash 或者 json 類型數(shù)據(jù)字段進(jìn)行搜索和聚合操作。

這里我們把被索引的 hash 或者 json 類型數(shù)據(jù)叫做源數(shù)據(jù)。

本文大綱如下,

使用體驗(yàn)

簡(jiǎn)單場(chǎng)景下,用 RediSearch 來平替 Elasticsearch 的使用場(chǎng)景已經(jīng)足夠。像是 Elasticsearch 中常用的查詢語法 AND 、OR 、IN 、NOT IN 、> 、< 、= 、like 等,在 RediSearch 中都是支持的。

此外 RediSearch 還支持聚合統(tǒng)計(jì)、停用詞、文本標(biāo)記和轉(zhuǎn)義、同義詞、標(biāo)簽、排序、向量查詢、中文分詞等。

就我個(gè)人來說,個(gè)人項(xiàng)目使用 RediSearch 作為全文搜索引擎已經(jīng)夠用了,它有占用內(nèi)存低、索引建立快、查詢數(shù)據(jù)性能足夠高等優(yōu)點(diǎn)。

后續(xù)發(fā)展

就目前官方對(duì) RediSearch 的支持更新來看,

最近一次提交記錄在 12 月 17 號(hào)。

可以看到 RediSearch 的更新頻率還是比較高的,而且是官方支持做的模塊,不用擔(dān)心后續(xù)無人維護(hù)。

雖然 Redis 天生支持分布式集群,但是 RediSearch 對(duì) Redis 集群的支持還不完善,引用官方說明,

官方針對(duì) RediSearch 的集群支持問題,提供了一個(gè) RediSearch 集群版本,但是這個(gè)版本只能在 Redis 企業(yè)版或者 Redis Cloud 上能使用,開源版還沒有,這一點(diǎn)需要告訴大家。

遇到 bug

首先在使用 RediSearch 的過程中,遇到了 bug 并發(fā)現(xiàn) bug 來源于 RediSearch,不要慌,也不要抱怨難用, 畢竟是開源項(xiàng)目,

大家可以看到 issue 列表中有很多 bug 沒有解決。

不過本著開源共進(jìn)的精神,希望大家發(fā)現(xiàn)了 bug 后,第一時(shí)間在 RediSearch 官方 github 上提個(gè) issue,方便官方發(fā)現(xiàn)并解決問題。

RediSearch Github 倉庫地址:https://github.com/RediSearch/RediSearch

下面我給大家用 newbee-mall-pro 項(xiàng)目作為樣本,給大家介紹下如何創(chuàng)建一個(gè)索引并關(guān)聯(lián)源數(shù)據(jù)。

newbee-mall-pro 項(xiàng)目地址:https://github.com/wayn111/newbee-mall-pro

添加源數(shù)據(jù)

在 newbee-mall-pro 項(xiàng)目中,已經(jīng)將商品數(shù)據(jù)以 hash 類型存入了 Redis 中,

其中,我們對(duì)于 key 名稱的定義規(guī)則是按照 newbee_mall:goods: + 商品ID。

這里我們的 key 名稱定義規(guī)則很重要,RediSearch 創(chuàng)建索引會(huì)基于 key 名稱前綴來生成。

hash 類型的 value 包含屬性如下,

  • goodsId : 商品 ID,唯一屬性,由數(shù)據(jù)庫商品表主鍵生成
  • goodsName : 商品名稱
  • goodsIntro : 商品簡(jiǎn)介
  • goodsCategoryId : 商品分類 ID,唯一屬性,由數(shù)據(jù)庫商品分類表主鍵生成
  • goodsSellStatus : 商品上架狀態(tài),0 代表下架,1 代表上架
  • sellingPrice : 商品售價(jià)
  • originalPrice : 商品原價(jià)
  • tag : 商品標(biāo)簽

在 newbee-mall-pro 中,添加源數(shù)據(jù)的方法已經(jīng)寫好了,代碼邏輯在 JedisSearch.addGoodsListIndex() 方法里,

public boolean addGoodsListIndex(String keyPrefix, List<Goods> list) {
    int chunk = 200;
    List<List<Goods>> partition = ListUtil.partition(list, chunk);
    AbstractPipeline pipelined = client.pipelined();
    for (List<Goods> goodsList : partition) {
        for (Goods goods : goodsList) {
            RsGoodsDTO target = new RsGoodsDTO();
            MyBeanUtil.copyProperties(goods, target);
            Map<String, String> hash = MyBeanUtil.toMap(target);
            // 支持中文
            hash.put("_language", Constants.GOODS_IDX_LANGUAGE);
            pipelined.hset(keyPrefix + goods.getGoodsId(), hash);
        }
    }
    pipelined.sync();
    return true;
}

上訴代碼中,其實(shí)就是把 list 商品列表以 hash 類型的數(shù)據(jù)結(jié)構(gòu)寫進(jìn) Redis 中,并且為了加快寫入速度,使用了 Redis 提供的管道操作。

需要注意的就是 hash 類型中新增了一個(gè) _language 字段,用于指定 RediSearch 對(duì)于源數(shù)據(jù)關(guān)聯(lián)的索引,要使用中文分詞查詢。

建立索引

RediSearch 通過提供一種簡(jiǎn)單且自動(dòng)的方式在 Redis hash 類型數(shù)據(jù)結(jié)構(gòu)上創(chuàng)建二級(jí)索引,并且內(nèi)部極大地簡(jiǎn)化了這一過程。(最終會(huì)出現(xiàn)更多數(shù)據(jù)結(jié)構(gòu))

如果我們要使用 RediSearch 查詢商品 hash 結(jié)構(gòu)里的 goodsName 字段,那么必須要對(duì)該字段建立索引。

Jedis 新建索引

所以這里,我給大家介紹下在 newbee-mall-pro 項(xiàng)目中,是如何建立索引的,代碼邏輯在 GoodsServiceImpl.syncRs() 方法中,

// 定義索引結(jié)構(gòu)
public boolean syncRs() {
    jedisSearch.dropIndex("idx:goods");
    Schema schema = new Schema()
            .addSortableTextField("goodsName", 1.0)
            .addSortableTextField("goodsIntro", 0.5)
            .addSortableNumericField("goodsId")
            .addSortableNumericField("goodsCategoryId")
            .addSortableNumericField("goodsSellStatus")
            .addSortableNumericField("sellingPrice")
            .addSortableNumericField("originalPrice")
            .addSortableTagField("tag", "|");
    jedisSearch.createIndex(Constants.GOODS_IDX_NAME, Constants.GOODS_IDX_PREFIX, schema);
}

上述代碼中,我們對(duì)商品 hash 結(jié)構(gòu)里的下方字段都建立了索引。

  • goodsName:文本類型,可排序,設(shè)置權(quán)重為 1.0
  • goodsIntro:文本類型,可排序,設(shè)置權(quán)重為 0.5
  • goodsId:數(shù)字類型,可排序
  • goodsCategoryId:數(shù)字類型,可排序
  • goodsSellStatus:數(shù)字類型,可排序
  • sellingPrice:數(shù)字類型,可排序
  • originalPrice:數(shù)字類型,可排序
  • tag:標(biāo)簽類型,可排序,設(shè)置分隔符為字符串 |

在 RediSerach 中可以添加的字段類型有 text、numberic、tag 等,可以設(shè)置是否排序。

并且還可以設(shè)置權(quán)重系數(shù),表示該字段已加權(quán)。這對(duì)于在搜索操作期間為特定字段分配不同的重要性級(jí)別非常有用,通常就是在條件篩選完成后的打分排序階段用于提升或者降低排名。

Redis 中的新建索引語法

當(dāng)我們把上面的 Jedis 新建索引的代碼轉(zhuǎn)換為 Redis 中的語法后,如下

> FT.CREATE idx:goods ON hash PREFIX 1 "newbeemall:goods:" \
SCHEMA goodsName TEXT SORTABLE WEIGHT 1.0 \
SCHEMA goodsIntro TEXT SORTABLE WEIGHT 0.5 \
goodsId NUMERIC SORTABLE \
goodsCategoryId NUMERIC SORTABLE \
goodsSellStatus NUMERIC SORTABLE \
sellingPrice NUMERIC SORTABLE \
originalPrice NUMERIC SORTABLE \
tag TAG SORTABLE SEPARATOR "|"

現(xiàn)在我給大家詳細(xì)介紹下這條命令:

  • FT.CREATE:RediSearch 中索引創(chuàng)建語法。
  • idx:goods:指定索引名稱,索引名稱將在所有鍵名稱中使用,因此請(qǐng)保持簡(jiǎn)短。
  • ON hash:指定索引關(guān)聯(lián)的結(jié)構(gòu)類型。需要注意的是,在 RediSearch 2.0 中僅支持哈希結(jié)構(gòu),隨著 RediSearch 更新,后續(xù)有望支持更多數(shù)據(jù)結(jié)構(gòu)。
  • PREFIX 1 "newbeemall:goods:":指定索引的關(guān)聯(lián)源數(shù)據(jù)的 key 前綴,可以指定多個(gè)前綴。
  • SCHEMA ...:字段定義,用于定義字段名稱、類型、是否排序、權(quán)重等??梢远x多個(gè)字段。

如果你想了解更多關(guān)于 ft.search 的語法以及字段定義相關(guān)的只是,可以打開官方文檔,

https://redis.io/docs/interact/search-and-query/basic-constructs/schema-definition

Redis 中查詢索引定義

在 RediSearch 中要查詢已經(jīng)存在的索引詳情也是很簡(jiǎn)單的,官方提供了 ft.info 索引名稱 的語法,用來打印索引詳情。

> FT.INFO idx:goods

最后聊兩句

本文給大家用我的開源項(xiàng)目 newbee-mall-pro 作為樣本,給大家細(xì)致的介紹了一番 RediSearch 在項(xiàng)目實(shí)戰(zhàn)中關(guān)于索引創(chuàng)建與關(guān)聯(lián)源數(shù)據(jù)的用法,希望大家喜歡。

到此這篇關(guān)于Redis全文搜索教程之創(chuàng)建索引并關(guān)聯(lián)源數(shù)據(jù)的文章就介紹到這了,更多相關(guān)Redis創(chuàng)建索引并關(guān)聯(lián)源數(shù)據(jù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Redis上實(shí)現(xiàn)分布式鎖以提高性能的方案研究

    Redis上實(shí)現(xiàn)分布式鎖以提高性能的方案研究

    這篇文章主要介紹了Redis上實(shí)現(xiàn)分布式鎖以提高性能的方案研究,其中重點(diǎn)需要理解異步算法與鎖的自動(dòng)釋放,需要的朋友可以參考下
    2015-12-12
  • 關(guān)于Redis數(shù)據(jù)庫入門詳細(xì)介紹

    關(guān)于Redis數(shù)據(jù)庫入門詳細(xì)介紹

    大家好,本篇文章主要講的是關(guān)于Redis數(shù)據(jù)庫入門詳細(xì)介紹,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • Redis恢復(fù)被移除集群的服務(wù)器實(shí)操步驟

    Redis恢復(fù)被移除集群的服務(wù)器實(shí)操步驟

    這篇文章主要為大家介紹了Redis恢復(fù)被移除集群的服務(wù)器實(shí)操步驟,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • Redis隊(duì)列和阻塞隊(duì)列的實(shí)現(xiàn)

    Redis隊(duì)列和阻塞隊(duì)列的實(shí)現(xiàn)

    本文主要介紹了Redis隊(duì)列和阻塞隊(duì)列的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-11-11
  • SpringBoot整合Mybatis-plus和Redis實(shí)現(xiàn)投票功能

    SpringBoot整合Mybatis-plus和Redis實(shí)現(xiàn)投票功能

    投票功能是一個(gè)非常常見的Web應(yīng)用場(chǎng)景,這篇文章將為大家介紹一下如何將Redis和Mybatis-plus整合到SpringBoot中,實(shí)現(xiàn)投票功能,感興趣的可以了解一下
    2023-05-05
  • 一文詳解Redis為什么一定要設(shè)置密碼原理

    一文詳解Redis為什么一定要設(shè)置密碼原理

    這篇文章主要為大家介紹了Redis為什么一定要設(shè)置密碼原理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-03-03
  • Redis實(shí)現(xiàn)庫存扣減的示例代碼

    Redis實(shí)現(xiàn)庫存扣減的示例代碼

    在日常開發(fā)中有很多地方都有類似扣減庫存的操作,本文主要介紹了Redis實(shí)現(xiàn)庫存扣減的示例代碼,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-07-07
  • redis中的事務(wù)操作案例分析

    redis中的事務(wù)操作案例分析

    這篇文章主要介紹了redis中的事務(wù)操作案例,結(jié)合具體實(shí)例形式詳細(xì)分析了redis事務(wù)操作的概念、原理、使用技巧與相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2019-07-07
  • 16個(gè)Redis的常見使用場(chǎng)景

    16個(gè)Redis的常見使用場(chǎng)景

    這篇文章主要介紹了Redis 常見使用場(chǎng)景的相關(guān)資料,需要的朋友可以參考下文
    2021-08-08
  • redis中scan命令的基本實(shí)現(xiàn)方法

    redis中scan命令的基本實(shí)現(xiàn)方法

    這篇文章主要給大家介紹了關(guān)于redis中scan命令的基本實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10

最新評(píng)論