NoSQL數(shù)據(jù)模型設(shè)計(jì) - 特殊應(yīng)用建模 - 關(guān)鍵字查詢

本文為NoSQL數(shù)據(jù)模型設(shè)計(jì)系列的一部分。

mongodb會(huì)為數(shù)組字段創(chuàng)建多值索引。這一特性提供一種方式實(shí)現(xiàn)關(guān)鍵查詢。

首先創(chuàng)建一個(gè)字符串?dāng)?shù)組字段包含需要的關(guān)鍵字,然后在這個(gè)字段上創(chuàng)建索引,最后利用這個(gè)索引進(jìn)行關(guān)鍵字查詢。

例如下面文檔包含主題關(guān)鍵字

{ title : "Moby-Dick" ,
  author : "Herman Melville" ,
  published : 1851 ,
  ISBN : 0451526996 ,
  topics : [ "whaling" , "allegory" , "revenge" , "American" ,
    "novel" , "nautical" , "voyage" , "Cape Cod" ]
}

在主題字段上創(chuàng)建數(shù)組,mongodb將會(huì)為每個(gè)主題值創(chuàng)建一個(gè)索引。

db.volumes.createIndex( { topics: 1 } )

基于此索引查詢

db.volumes.findOne( { topics : "voyage" }, { title: 1 } )

關(guān)鍵字索引的限制

  • 不支持文字解析
  • 不支持同義詞分析
  • 不支持比重分析
  • 不支持異步索引

完整內(nèi)容請(qǐng)查看NoSQL數(shù)據(jù)模型設(shè)計(jì)系列

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容