亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

教你怎樣在MySQL中提高全文搜索效率

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

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

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數據庫搜索界面的時候,您可以嘗試這一方法。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
www高清在线视频日韩欧美| 日韩极品精品视频免费观看| 欧美日韩国产专区| 亚洲国内高清视频| 亚洲精品乱码久久久久久按摩观| 国产精品久久久久久久天堂| 久久夜色精品国产欧美乱| 久久精品成人欧美大片| 亚洲欧美综合精品久久成人| 亚洲人成电影在线播放| 久久电影一区二区| 精品久久久国产| 欧美一区二区三区精品电影| 欧美日韩免费观看中文| 热久久免费国产视频| 成人美女免费网站视频| 成人av番号网| 亚洲天堂日韩电影| 亚洲乱码一区二区| 精品二区三区线观看| 激情av一区二区| 91香蕉亚洲精品| 欧美乱大交xxxxx另类电影| 亚洲精品自拍第一页| 日韩亚洲第一页| 欧美孕妇毛茸茸xxxx| 欧美激情视频网| 久久久综合av| 国产一区二区久久精品| 欧美一级淫片播放口| 欧美日韩在线视频一区二区| 国产一区二区丝袜| 欧美日韩中文字幕日韩欧美| 亚洲人成人99网站| 国产国产精品人在线视| 亚洲第一色在线| 欧美日韩综合视频网址| 日韩欧美在线观看| 欧美日韩不卡合集视频| 亚洲男人第一av网站| 91精品视频在线| 国产精品色婷婷视频| 91久久国产精品91久久性色| 亚洲欧美日韩综合| 欧美一级免费看| 91wwwcom在线观看| 欧美精品中文字幕一区| 国产乱人伦真实精品视频| 亚洲欧美日韩精品久久奇米色影视| 日本不卡视频在线播放| 欧美日韩国产成人在线| 欧美精品制服第一页| 懂色aⅴ精品一区二区三区蜜月| 国产精品小说在线| 国模精品视频一区二区| 国产精品最新在线观看| 97精品一区二区视频在线观看| 久久久精品国产一区二区| 日韩av在线直播| 97久久超碰福利国产精品…| 久久成人人人人精品欧| 一区二区日韩精品| 欧美日韩美女视频| 久久久久久高潮国产精品视| 亚洲天堂男人的天堂| 国产精品久久二区| 91亚洲va在线va天堂va国| 日韩欧美a级成人黄色| 在线看日韩av| 亚洲美女精品久久| 国产精品海角社区在线观看| 亚洲精品国产欧美| 国产精自产拍久久久久久蜜| 国产亚洲成av人片在线观看桃| 国产精品狼人色视频一区| 中文字幕av一区二区| 成人亚洲激情网| 欧美亚洲在线播放| 国产一区二区免费| 亚洲色图50p| 日本在线观看天堂男亚洲| 精品视频久久久久久| 久久精品这里热有精品| 日韩黄色高清视频| 91伊人影院在线播放| 中国china体内裑精亚洲片| 日韩精品欧美激情| 欧美贵妇videos办公室| 成人性生交大片免费看视频直播| 久久精视频免费在线久久完整在线看| 亚洲欧美日韩国产中文| 欧美性受xxxx白人性爽| 成人网在线视频| 亚洲成人网av| 亚洲aⅴ日韩av电影在线观看| 一本一本久久a久久精品综合小说| 午夜剧场成人观在线视频免费观看| 欧美激情按摩在线| 92国产精品久久久久首页| 美日韩精品视频免费看| 欧美日韩国产一区中文午夜| 亚洲国产99精品国自产| 中文字幕免费精品一区高清| 欧美日韩在线第一页| 97久久超碰福利国产精品…| 国产精品久久久久久久久久ktv| 青草青草久热精品视频在线网站| 亚洲最大成人网色| 久久久久国产精品免费网站| 亚洲影院高清在线| 成人久久精品视频| 欧美视频在线观看免费| 色中色综合影院手机版在线观看| 国产成人精品一区二区| 日韩成人在线免费观看| 午夜剧场成人观在线视频免费观看| 黑人巨大精品欧美一区二区三区| 亚洲人成电影网站色…| 国产不卡在线观看| 亚洲精品一区二区三区婷婷月| 日产精品久久久一区二区福利| 欧美黄色片在线观看| 91香蕉亚洲精品| 亚洲精品久久久久久久久| 精品国产依人香蕉在线精品| 国产成人综合精品在线| 亚洲女人天堂视频| 久久精品国产91精品亚洲| 欧美在线不卡区| 成人激情视频在线播放| 精品五月天久久| 久久成人综合视频| 中文字幕欧美视频在线| 久久免费视频网| 亚洲综合视频1区| 日韩av在线精品| 超在线视频97| 国产精品美女www| 久久精品男人天堂| 正在播放欧美一区| 国产不卡一区二区在线播放| 国产丝袜一区二区三区| 九九九热精品免费视频观看网站| 欧美专区第一页| 亚洲丝袜在线视频| 亚洲国产欧美久久| 在线成人激情视频| 人人爽久久涩噜噜噜网站| 在线观看日韩av| 日本成熟性欧美| 欧美丰满片xxx777| 久久国产精品影视| 久久久亚洲精品视频| 亚洲区bt下载| 久久精品国产成人精品| 精品国产成人在线| 国产乱人伦真实精品视频| 精品亚洲国产成av人片传媒| 18一19gay欧美视频网站| 亚洲欧美日本另类| 日本午夜精品理论片a级appf发布| 国产一区二区三区中文| 欧美在线观看www| 97超级碰在线看视频免费在线看|