mysql布爾文本搜索圖文說明教程
發(fā)表時(shí)間:2023-09-06 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]MySQL支持全文本搜索的另外一種形式,稱為布爾方式(booleanmode)。以布爾方式,可以提供關(guān)于如下內(nèi)容的細(xì)節(jié):要匹配的詞;1.要排斥的詞(如果某行包含這個(gè)詞,則不返回該行,即使它包含其他指定的詞也是如此);2.排列提示(指定某些詞比其他詞更重要,更重要的詞等級(jí)更高);3.表達(dá)式分組;4....
MySQL支持全文本搜索的另外一種形式,稱為布爾方式(booleanmode)。以布爾方式,可以提供關(guān)于如下內(nèi)容的細(xì)節(jié):
要匹配的詞;
1.要排斥的詞(如果某行包含這個(gè)詞,則不返回該行,即使它包含其他指定的詞也是如此);
2.排列提示(指定某些詞比其他詞更重要,更重要的詞等級(jí)更高);
3.表達(dá)式分組;
4.另外一些內(nèi)容。
即使沒有 FULLTEXT 索引也可以使用 布爾方式不同于迄今為止使用的全文本搜索語法的地方在于,即使沒有定義FULLTEXT 索引,也可以使用它。但這是一種非常緩慢的操作(其性能將隨著數(shù)據(jù)量的增加而降低)。
為演示 IN BOOLEAN MODE 的作用,舉一個(gè)簡單的例子:
輸入:
select note_text from productnotes where match(note_text) against('anvils' in boolean mode);
輸出:
分析:此全文本搜索檢索包含詞 heavy 的所有行(有兩行)。其中使用了關(guān)鍵字 IN BOOLEAN MODE ,但實(shí)際上沒有指定布爾操作符,因此,其結(jié)果與沒有指定布爾方式的結(jié)果相同。
IN BOOLEAN MODE 的行為差異 雖然這個(gè)例子的結(jié)果與沒有IN BOOLEAN MODE 的相同,但其行為有一個(gè)重要的差別(即使在這個(gè)特殊的例子沒有表現(xiàn)出來)。
為了匹配包含 heavy 但不包含任意以 rope 開始的詞的行,可使用以下查詢:
輸入:
select note_text from productnotes where match(note_text) against('heavy -rope' in boolean mode);
輸出:
分析:這次只返回一行。這一次仍然匹配詞 heavy ,但 -rope* 明確地指示MySQL排除包含 rope* (任何以 rope 開始的詞,包括ropes )的行,這就是為什么上一個(gè)例子中的第一行被排除的原因。
在MySQL 4.x中所需的代碼更改 如果你使用的是MySQL4.x,則上面的例子可能不返回任何行。這是 * 操作符處理中的一個(gè)錯(cuò)誤。為在MySQL 4.x中使用這個(gè)例子,使用 -ropes 而不是 -rope* (排除 ropes 而不是排除任何以 rope 開始的詞)。
我們已經(jīng)看到了兩個(gè)全文本搜索布爾操作符 - 和 * ,-排除一個(gè)詞,而 *是截?cái)嗖僮鞣ǹ上胂鬄橛糜谠~尾的一個(gè)通配符)。下表列出支持的所有布爾操作符。
下面舉幾個(gè)例子,說明某些操作符如何使用:
輸入:
select note_text from productnotes where match(note_text) against('+rabbit +bait' in boolean mode);
分析:這個(gè)搜索匹配包含詞 rabbit 和 bait 的行。
輸入:
select note_text from productnotes where match(note_text) agains('rabbit bait' in boolean mode);
分析:沒有指定操作符,這個(gè)搜索匹配包含 rabbit 和 bait 中的至少一個(gè)詞的行。
輸入:
select note_text from productnotes where match(note_text) agains('"rabbit bait"' in boolean mode);
分析:這個(gè)搜索匹配短語 rabbit bait 而不是匹配兩個(gè)詞 rabbit 和bait 。
輸入:
select note_text from productnotes where match(note_text) agains('>rabbit <bcarrot' in boolean mode);
分析:匹配 rabbit 和 carrot ,增加前者的等級(jí),降低后者的等級(jí)。
輸入:
select note_text from productnotes where match(note_text) agains('+safe +(<combination)' in boolean mode);
分析:這個(gè)搜索匹配詞 safe 和 combination ,降低后者的等級(jí)。
排列而不排序 在布爾方式中,不按等級(jí)值降序排序返回的行。
以上就是mysql布爾文本搜索教程的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!
學(xué)習(xí)教程快速掌握從入門到精通的SQL知識(shí)。