亚洲韩日午夜视频,欧美日韩在线精品一区二区三区,韩国超清无码一区二区三区,亚洲国产成人影院播放,久草新在线,在线看片AV色

您好,歡迎來(lái)到思海網(wǎng)絡(luò),我們將竭誠(chéng)為您提供優(yōu)質(zhì)的服務(wù)! 誠(chéng)征網(wǎng)絡(luò)推廣 | 網(wǎng)站備案 | 幫助中心 | 軟件下載 | 購(gòu)買流程 | 付款方式 | 聯(lián)系我們 [ 會(huì)員登錄/注冊(cè) ]
促銷推廣
客服中心
業(yè)務(wù)咨詢
有事點(diǎn)擊這里…  531199185
有事點(diǎn)擊這里…  61352289
點(diǎn)擊這里給我發(fā)消息  81721488
有事點(diǎn)擊這里…  376585780
有事點(diǎn)擊這里…  872642803
有事點(diǎn)擊這里…  459248018
有事點(diǎn)擊這里…  61352288
有事點(diǎn)擊這里…  380791050
技術(shù)支持
有事點(diǎn)擊這里…  714236853
有事點(diǎn)擊這里…  719304487
有事點(diǎn)擊這里…  1208894568
有事點(diǎn)擊這里…  61352289
在線客服
有事點(diǎn)擊這里…  531199185
有事點(diǎn)擊這里…  61352288
有事點(diǎn)擊這里…  983054746
有事點(diǎn)擊這里…  893984210
當(dāng)前位置:首頁(yè) >> 技術(shù)文章 >> 文章瀏覽
技術(shù)文章

在MySQL中提高全文搜索效率

添加時(shí)間:2013-9-22 19:02:06  添加: 思海網(wǎng)絡(luò) 
很多互聯(lián)網(wǎng)應(yīng)用程序都提供了全文搜索功能,用戶可以使用一個(gè)詞或者詞語(yǔ)片斷作為查詢項(xiàng)目來(lái)定位匹配的記錄。在后臺(tái),這些程序使用在一個(gè)SELECT查詢中的LIKE語(yǔ)句來(lái)執(zhí)行這種查詢,盡管這種方法可行,但對(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)目。

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

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

以下為引用的內(nèi)容:
mysql> CREATE TABLE reviews (id INT(5)
PRIMARY KEY NOT NULL AUTO_INCREMENT, data TEXT);
 
以上命令創(chuàng)建了一個(gè)簡(jiǎn)單的音樂(lè)專集資料庫(kù)(主要是整段的文字),然后向這個(gè)表格中添加一些記錄:

以下為引用的內(nèi)容:

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ù)的正確錄入:

以下為引用的內(nèi)容:

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),定義您要作為全文搜索索引的字段:

以下為引用的內(nè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)被添加了:

以下為引用的內(nèi)容:

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查詢,以下是一個(gè)簡(jiǎn)單的例子,可以來(lái)查找含有單詞“single”的記錄:

以下為引用的內(nèi)容:

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()來(lái)查看­-只需用逗號(hào)來(lái)分割字段列表。

當(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)來(lái)決定的,查看MySQL的用戶手冊(cè)可以得到更多的信息。

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

以下為引用的內(nèi)容:

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)

您還可以使用邏輯搜索修飾符來(lái)進(jìn)行更精確的搜索,這通過(guò)在AGAINST語(yǔ)句中添加特殊的IN BOOLEAN MODE修飾符來(lái)實(shí)現(xiàn),在以下的例子中,將查找含有單詞“single”但是沒(méi)有“Madonna”的記錄:

以下為引用的內(nèi)容:

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

+----+

| id |

+----+

|  1 |

+----+

1 row in set (0.00 sec)

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

以下為引用的內(nèi)容:

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

| id |

+----+

|  3 |

|  2 |

+----+

2 rows in set (0.00 sec)

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

以下為引用的內(nèi)容:

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語(yǔ)句,進(jìn)行全文搜索的更有效的方法,當(dāng)您下一次需要編寫(xiě)MySQL數(shù)據(jù)庫(kù)搜索界面的時(shí)候,您可以嘗試這一方法。

關(guān)鍵字:MySQL、數(shù)據(jù)庫(kù)、全文搜索

分享到:

頂部 】 【 關(guān)閉
版權(quán)所有:佛山思海電腦網(wǎng)絡(luò)有限公司 ©1998-2024 All Rights Reserved.
聯(lián)系電話:(0757)22630313、22633833
中華人民共和國(guó)增值電信業(yè)務(wù)經(jīng)營(yíng)許可證: 粵B1.B2-20030321 備案號(hào):粵B2-20030321-1
網(wǎng)站公安備案編號(hào):44060602000007 交互式欄目專項(xiàng)備案編號(hào):200303DD003  
察察 工商 網(wǎng)安 舉報(bào)有獎(jiǎng)  警警  手機(jī)打開(kāi)網(wǎng)站