麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數據庫 > MySQL > 正文

在MySQL中獲得更好的全文搜索結果

2024-07-25 19:09:43
字體:
來源:轉載
供稿:網友

很多互聯網應用程序都提供了全文搜索功能,用戶可以使用一個詞或者詞語片斷作為查詢項目來定位匹配的記錄。在后臺,這些程序使用在一個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)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 成人精品一区二区三区中文字幕 | 久草手机视频在线观看 | 538任你躁在线精品视频网站 | 欧美一级淫片a免费播放口 91九色蝌蚪国产 | 久久国产成人午夜av浪潮 | 二区三区四区视频 | 国产成人精品免费视频大全办公室 | 成年人毛片视频 | 欧美福利视频一区二区三区 | 青草伊人网 | 国产精品剧情一区二区三区 | 免费国产在线视频 | 国产精选久久 | 曰韩毛片 | 欧美成人黄色小视频 | 久久精品亚洲一区 | 久久精品久久久久 | 最新毛片在线观看 | 国产精品免费麻豆入口 | 看免费一级毛片 | 污黄视频在线播放 | 日本一区二区不卡高清 | 国产精品jk白丝蜜臀av软件 | 成人国产精品久久久 | av在线播放亚洲 | 久久久综合 | 国产美女视频一区二区三区 | 久久久久久久久成人 | 欧洲成人在线视频 | 国产精品久久久久免费视频 | 国产精品一区在线看 | 亚洲伊人色欲综合网 | 91精品国产九九九久久久亚洲 | 特片网久久 | 久久草草影视免费网 | 成人午夜在线播放 | 在线a亚洲视频播放在线观看 | 毛片区 | 96视频在线免费观看 | 久久久久免费精品国产小说色大师 | av在线免费网 |