很多互聯網應用程序都提供了全文搜索功能,用戶可以使用一個詞或者詞語片斷作為查詢項目來定位匹配的記錄。在后臺,這些程 " /> 孕妇bbwbbwbbwbbw超清,国产高清视频青青青在线,成人小视频在线观看

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

mysql 搜索之簡單應用

如何在MySQL中獲得更好的全文搜索結果  
作者: Techrepublic.com.com 
2006-04-03 11:14:53 




很多互聯網應用程序都提供了全文搜索功能,用戶可以使用一個詞或者詞語片斷作為查詢項目來定位匹配的記錄。在后臺,這些程序使用在一個SELECT查詢中的LIKE語句來執行這種查詢,盡管這種方法可行,但對于全文查找而言,這是一種效率極端低下的方法,尤其在處理大量數據的時候。

MySQL針對這一問題提供了一種基于內建的全文查找方式的解決方案。在此,開發者只需要簡單地標記出需要全文查找的字段,然后使用特殊的MySQL方法在那些字段運行搜索,這不僅僅提高了性能和效率(因為MySQL對這些字段做了索引來優化搜索),而且實現了更高質量的搜索,因為MySQL使用自然語言來智能地對結果評級,以去掉不相關的項目。

這篇文章將向您講述在MySQL中如何進行全文搜索。

1、設置基本表格

從創建例子表格開始,使用以下的SQL命令:

mysql> CREATE TABLE reviews (id INT(5) PRIMARY KEY NOT NULL AUTO_INCREMENT, data TEXT);

以上命令創建了一個簡單的音樂專集資料庫(主要是整段的文字),然后向這個表格中添加一些記錄:

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!');

驗證數據的正確錄入:

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、定義全文搜索字段

接下來,定義您要作為全文搜索索引的字段

mysql> ALTER TABLE reviews ADD FULLTEXT INDEX (data);

Query OK, 3 rows affected (0.21 sec)

Records: 3  Duplicates: 0  Warnings: 0

使用SHOW INDEXES命令來檢查索引已經被添加了:

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、運行全文搜索

當您擁有了數據和索引,就可以使用MySQL的全文搜索了,最簡單的全文搜索方式是帶有MATCH...AGAINST語句的SELECT查詢,以下是一個簡單的例子,可以來查找含有單詞“single”的記錄:

mysql> SELECT id FROM reviews WHERE MATCH (data) AGAINST ('single');+----+

| id |

+----+

|  1 |

|  2 |

+----+

2 rows in set (0.00 sec)

在此,MATCH()將作為參數傳遞給它的字段中的文字與傳遞給AGAINST()的參數進行比較,如果有匹配的,那就按照正常的方式返回。注意您可以傳遞不止一個字段用MATCH()來查看­-只需用逗號來分割字段列表。

當MySQL收到了一個全文搜索的請求,它就在內部對每個記錄進行評分,不匹配的記錄得分為零,而“更相關”的記錄會得到比“不太相關”的記錄相對更高的分數。相關性是由MySQL的一系列區分標準來決定的,查看MySQL的用戶手冊可以得到更多的信息。

想看到每個記錄的評分如何,只需要返回MATCH()方法作為結果集的一部分,如下所示:

mysql> SELECT id, MATCH (data) AGAINST ('rock') FROM reviews;

+----+-------------------------------+

| id | MATCH (data) AGAINST ('rock') |

+----+-------------------------------+

|  1 |                             0 |

|  2 |                             0 |

|  3 |               1.3862514533815 |

+----+-------------------------------+

3 rows in set (0.00 sec)

4、使用邏輯搜索修飾符(Boolean search modifiers)

您還可以使用邏輯搜索修飾符來進行更精確的搜索,這通過在AGAINST語句中添加特殊的IN BOOLEAN MODE修飾符來實現,在以下的例子中,將查找含有單詞“single”但是沒有“Madonna”的記錄:

mysql> SELECT id FROM reviews WHERE MATCH (data) AGAINST ('+single -madonna' IN BOOLEAN MODE);

+----+

| id |

+----+

|  1 |

+----+

1 row in set (0.00 sec)

這一搜索特性通常用于搜索單詞片斷(而不是完整的詞語),這可以通過在IN BOOLEAN MODE語句中的*(星號)操作符來實現,以下的例子展示了如何查找單詞中含有“hot”的記錄:

mysql> SELECT id FROM reviews WHERE MATCH (data) AGAINST ('hot*' IN BOOLEAN MODE);+----+

| id |

+----+

|  3 |

|  2 |

+----+

2 rows in set (0.00 sec)

您還可以使用這種方法來查找至少一個傳遞到AGAINST的參數中,以下的例子查找了至少包含單詞“hell”和“rocks”中的一個的記錄:

mysql> SELECT id FROM reviews WHERE MATCH (data) AGAINST ('hell rocks' IN BOOLEAN MODE);

+----+

| id |

+----+

|  1 |

|  3 |

+----+

2 rows in set (0.00 sec)

以上的這些例子演示了相對于傳統的SELECT...LIKE語句,進行全文搜索的更有效的方法,當您下一次需要編寫MySQL數據庫搜索界面的時候,您可以嘗試這一方法。

php技術mysql 搜索之簡單應用,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲区视频在线观看 | 2021扫黑风暴在线观看免费完整版 | 亚洲乱亚洲乱妇在线观看 | 婚后被调教当众高潮H喷水 回复术士勇者免费观看全集 | 青青在线视版在线播放 | 精品视频免费在线观看 | 国产精品99久久久久久AV蜜臀 | 久久99国产精品二区不卡 | 精品性影院一区二区三区内射 | 日本阿v片在线播放免费 | 午夜亚洲精品不卡在线 | 美女被黑人巨大进入 | 尤物99久久久合集一区区 | 青青青草免费 | 色偷偷成人网免费视频男人的天堂 | 97在线观看免费 | 国产精品白浆精子流水合集 | 一本到2v不卡区 | 麻豆精品传媒2021网站入口 | 青娱乐极品视觉盛宴国产视频 | 村妇偷人内射高潮迭起 | 免费鲁丝片一级在线观看 | 竹菊精品久久久久久久99蜜桃 | 色怕怕| 幼儿交1300部一区二区 | 日日夜夜操操操 | 最近2019中文字幕免费版视频 | 日本漫画之无彩翼漫画 | 语文老师扒开胸罩喂我奶 | 欧美片第1页 综合 | 欧洲美女高清一级毛片 | 久久久久影视 | 美女脱了内裤张开腿让男人爽 | 97在线视频免费观看97 | 涩里番app黄版网站 色综合伊人色综合网站中国 | 国产精品成人网 | 九九热在线视频观看这里只有精品 | 海角国精产品一区一区三区糖心 | 护士WC女子撒尿 | 成人在线观看国产 | 一级毛片在线免费视频 |