欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

如何在MySQL中獲得更好的全文搜索結(jié)果

系統(tǒng) 1940 0

很多互聯(lián)網(wǎng)應(yīng)用程序都提供了全文搜索功能,用戶可以使用一個(gè)詞或者詞語片斷作為查詢項(xiàng)目來定位匹配的記錄。在后臺(tái),這些 程序使用在一個(gè)SELECT查詢中的LIKE語句來執(zhí)行這種查詢,盡管這種方法可行,但對(duì)于全文查找而言,這是一種效率極端低下的方法,尤其在處理大量數(shù) 據(jù)的時(shí)候。

<!--start banner ad--> <!--ba--> <noscript> &lt;A &gt; &lt;IMG SRC="http://ad.cn.doubleclick.net/ad/messagingplus.zdnet.com.cn/developer/database;sz=1x1;ord=935048942?" border=0 &gt;&lt;/A&gt; </noscript> <!--end banner ad-->

MySQL針對(duì)這一問題提供了一種基于內(nèi)建的全文查找方式的解決方案。在此,開發(fā)者只需要簡(jiǎn)單地標(biāo)記出需要全文查找的字段,然后使用特殊的 MySQL方法在那些字段運(yùn)行搜索,這不僅僅提高了性能和效率(因?yàn)镸ySQL對(duì)這些字段做了索引來優(yōu)化搜索),而且實(shí)現(xiàn)了更高質(zhì)量的搜索,因?yàn)?MySQL使用自然語言來智能地對(duì)結(jié)果評(píng)級(jí),以去掉不相關(guān)的項(xiàng)目。

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

1 、設(shè)置基本表格

從創(chuàng)建例子表格開始,使用以下的SQL命令:

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

以上命令創(chuàng)建了一個(gè)簡(jiǎ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 、定義全文搜索字段

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

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

Query OK, 3 rows affected (0.21 sec)

Records: 3 Duplicates: 0 Warnings: 0

使用SHOW INDEXES命令來檢查索引已經(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語句的SELECT查詢,以下是一個(gè)簡(jiǎn)單的例子,可以來查找含有單詞“single”的記錄:

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

| id |

+----+

| 1 |

| 2 |

+----+

2 rows in set (0.00 sec)

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

當(dāng)MySQL收到了一個(gè)全文搜索的請(qǐng)求,它就在內(nèi)部對(duì)每個(gè)記錄進(jìn)行評(píng)分,不匹配的記錄得分為零,而“更相關(guān)”的記錄會(huì)得到比“不太相關(guān)”的記錄相對(duì)更高的分?jǐn)?shù)。相關(guān)性是由MySQL的一系列區(qū)分標(biāo)準(zhǔn)來決定的,查看MySQL的用戶手冊(cè)可以得到更多的信息。

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

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

您還可以使用邏輯搜索修飾符來進(jìn)行更精確的搜索,這通過在AGAINST語句中添加特殊的IN BOOLEAN MODE修飾符來實(shí)現(xiàn),在以下的例子中,將查找含有單詞“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語句中的*(星號(hào))操作符來實(shí)現(xiàn),以下的例子展示了如何查找單詞中含有“hot”的記錄:

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

| id |

+----+

| 3 |

| 2 |

+----+

2 rows in set (0.00 sec)

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

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

+----+

| id |

+----+

| 1 |

| 3 |

+----+

2 rows in set (0.00 sec)

以上的這些例子演示了相對(duì)于傳統(tǒng)的SELECT...LIKE語句,進(jìn)行全文搜索的更有效的方法,當(dāng)您下一次需要編寫MySQL數(shù)據(jù)庫(kù)搜索界面的時(shí)候,您可以嘗試這一方法。

如何在MySQL中獲得更好的全文搜索結(jié)果


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 国产不卡视频在线播放 | 91.成人天堂一区 | 天天骑夜夜操 | 亚洲 欧洲 偷拍 校园 另类 | 久久男人视频 | 亚洲我不卡 | 欧美福利视频一区二区三区 | 国产精品永久免费 | 久久精品这里是免费国产 | 国产精品久久久久久久久 | 亚洲精品国产成人一区二区 | 一级一级毛片免费看 | 久久成人18免费网站 | a欧美| 欧美日剧在线免费 | 一区二区成人 | 欧美zozozo人禽交 | 超级在线牛碰碰视频 | 色在线视频网站 | 亚洲一区国产 | 国产成人精品一区二区三在线观看 | 日韩精品www | 一级片在线 | 欧美精品导航 | 久久97精品久久久久久久看片 | 色狠狠色狠狠综合一区 | 亚洲午夜av久久乱码 | 国产噜噜噜精品免费 | 欧美国产一区二区三区 | gogo全球大胆高清人露出91 | 国产精品第一页在线 | 天天草夜夜操 | 色影影院 | 欧美福利一区二区三区 | jizz丝袜老师 | 二区三区视频 | 啊啊啊网站 | 99久久精品费精品国产一区二 | 一级毛片大全 | 青草视频在线免费观看 | 亚洲第一在线 |