很多互聯(lián)網(wǎng)應(yīng)用程序都提供了全文搜索功能,用戶(hù)可以使用一個(gè)詞或者詞語(yǔ)片斷作為查詢(xún)項(xiàng)目來(lái)定位匹配的記錄。在后臺(tái),這些程序使用在一個(gè)SELECT查詢(xún)中的LIKE語(yǔ)句來(lái)執(zhí)行這種查詢(xún),盡管這種方法可行,但對(duì)于全文查找而言,這是一種效率極端低下的方法,尤其在處理大量數(shù)據(jù)的時(shí)候。
MySQL針對(duì)這一問(wèn)題提供了一種基于內(nèi)建的全文查找方式的解決方案。在此,開(kāi)發(fā)者只需要簡(jiǎn)單地標(biāo)記出需要全文查找的字段,然后使用特殊的MySQL方法在那些字段運(yùn)行搜索,這不僅僅提高了性能和效率(因?yàn)镸ySQL對(duì)這些字段做了索引來(lái)優(yōu)化搜索),而且實(shí)現(xiàn)了更高質(zhì)量的搜索,因?yàn)镸ySQL使用自然語(yǔ)言來(lái)智能地對(duì)結(jié)果評(píng)級(jí),以去掉不相關(guān)的項(xiàng)目。
這篇文章將向您講述在MySQL中如何進(jìn)行全文搜索。
1、設(shè)置基本表格
從創(chuàng)建例子表格開(kāi)始,使用以下的SQL命令:
mysql> CREATE TABLE reviews (id INT(5) PRIMARY KEY NOT NULL AUTO_INCREMENT, data TEXT); |
以上命令創(chuàng)建了一個(gè)簡(jiǎn)單的音樂(lè)專(zhuān)集資料庫(kù)(主要是整段的文字),然后向這個(gè)表格中添加一些記錄:
mysql> INSERT INTO `reviews` (`id`, `data`) VALUES(1, 'Gingerboy has a new single out called Throwing Rocks. It/'s great!');mysql> INSERT INTO `reviews` (`id`, `data`) VALUES (2, 'Hello all, I really like the new Madonna single. One of the hottest tracks currently playing...I/'ve been listening to it all day');mysql> INSERT INTO `reviews` (`id`, `data`)VALUES (3, 'Have you heard the new band Hotter Than Hell?They have five members and they burn their instruments when they play in concerts. These guys totally rock! Like, awesome, dude!'); |
驗(yàn)證數(shù)據(jù)的正確錄入:
mysql> SELECT * FROM reviews;+----+--------------------------------------------+| id | data |+----+--------------------------------------------+| 1 | Gingerboy has a new single out called ... || 2 | Hello all, I really like the new Madon ... || 3 | Have you heard the new band Hotter Than... |+----+--------------------------------------------+3 rows in set (0.00 sec) |
2、定義全文搜索字段
接下來(lái),定義您要作為全文搜索索引的字段
mysql> ALTER TABLE reviews ADD FULLTEXT INDEX (data);Query OK, 3 rows affected (0.21 sec)Records: 3 Duplicates: 0 Warnings: 0 |
使用SHOW INDEXES命令來(lái)檢查索引已經(jīng)被添加了:
mysql> SHOW INDEXES FROM reviews;+---------+---------------+--------+------+------------+---------+| Table | Column_name | Packed | Null | Index_type | Comment |----------+---------------+--------+------+------------+---------+| reviews | id | NULL | | BTREE | || reviews | data | NULL | YES | FULLTEXT | |+---------+---------------+--------+------+------------+---------+2 rows in set (0.01 sec) |
3、運(yùn)行全文搜索
當(dāng)您擁有了數(shù)據(jù)和索引,就可以使用MySQL的全文搜索了,最簡(jiǎn)單的全文搜索方式是帶有MATCH...AGAINST語(yǔ)句的SELECT查詢(xún),以下是一個(gè)簡(jiǎn)單的例子,可以來(lái)查找含有單詞“single”的記錄:
mysql> SELECT id FROM reviews WHERE MATCH (data) AGAINST ('single');+----+| id |+----+| 1 || 2 |+----+2 rows in set (0.00 sec) |