精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

利用MySQL內(nèi)置函數(shù)實現(xiàn)全文搜索功能

數(shù)據(jù)庫 MySQL 數(shù)據(jù)庫運維
本文主要介紹應(yīng)用MySQL中的內(nèi)置函數(shù)來實現(xiàn)全文搜索功能,希望本文可以給您帶來幫助。

MATCH (col1,col2,...) AGAINST (expr [IN BOOLEAN MODE | WITH QUERY EXPANSION])

MySQL支持全文索引和搜索功能。MySQL中的全文索引類型FULLTEXT的索引。  FULLTEXT 索引僅可用于 MyISAM 表;他們可以從CHAR、VARCHAR或TEXT列中作為CREATE TABLE語句的一部分被創(chuàng)建,或是隨后使用ALTER TABLE 或 CREATE INDEX被添加。對于較大的數(shù)據(jù)集,將你的資料輸入一個沒有FULLTEXT索引的表中,然后創(chuàng)建索引,其速度比把資料輸入現(xiàn)有FULLTEXT索引的速度更為快。

全文搜索同MATCH()函數(shù)一起執(zhí)行。

mysql> CREATE TABLE articles (
    ->   id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,
    ->   title VARCHAR(200),
    ->   body TEXT,
    ->   FULLTEXT (title,body)
    -> );
Query OK, 0 rows affected (0.00 sec)
 
mysql> INSERT INTO articles (title,body) VALUES
    -> ('MySQL Tutorial','DBMS stands for DataBase ...'),
    -> ('How To Use MySQL Well','After you went through a ...'),
    -> ('Optimizing MySQL','In this tutorial we will show ...'),
    -> ('1001 MySQL Tricks','1. Never run mysqld as root. 2. ...'),
    -> ('MySQL vs. YourSQL','In the following database comparison ...'),
    -> ('MySQL Security','When configured properly, MySQL ...');
Query OK, 6 rows affected (0.00 sec)
Records: 6  Duplicates: 0  Warnings: 0
 
mysql> SELECT * FROM articles
    -> WHERE MATCH (title,body) AGAINST ('database');
+----+-------------------+------------------------------------------+
| id | title             | body                                     |
+----+-------------------+------------------------------------------+
|  5 | MySQL vs. YourSQL | In the following database comparison ... |
|  1 | MySQL Tutorial    | DBMS stands for DataBase ...             |
+----+-------------------+------------------------------------------+
2 rows in set (0.00 sec)

MATCH()函數(shù)對于一個字符串執(zhí)行資料庫內(nèi)的自然語言搜索。一個資料庫就是1套1個或2個包含在FULLTEXT內(nèi)的列。搜索字符串作為對AGAINST()的參數(shù)而被給定。對于表中的每一行, MATCH() 返回一個相關(guān)值,即, 搜索字符串和 MATCH()表中指定列中該行文字之間的一個相似性度量。

在默認狀態(tài)下, 搜索的執(zhí)行方式為不區(qū)分大小寫方式。然而,你可以通過對編入索引的列使用二進制排序方式執(zhí)行區(qū)分大小寫的全文搜索。 例如,可以向一個使用latin1字符集的列給定latin1_bin 的排序方式,對于全文搜索區(qū)分大小寫。

如上述所舉例子,當MATCH()被用在一個 WHERE 語句中時,相關(guān)值是非負浮點數(shù)。零相關(guān)的意思是沒有相似性。相關(guān)性的計算是基于該行中單詞的數(shù)目, 該行中獨特子的數(shù)目,資料庫中單詞的總數(shù),以及包含特殊詞的文件(行)數(shù)目。

對于自然語言全文搜索,要求MATCH() 函數(shù)中命名的列和你的表中一些FULLTEXT索引中包含的列相同。對于前述問訊, 注意,MATCH()函數(shù)(題目及全文)中所命名的列和文章表的FULLTEXT索引中的列相同。若要分別搜索題目和全文,應(yīng)該對每個列創(chuàng)建FULLTEXT索引。

或者也可以運行布爾搜索或使用查詢擴展進行搜索。

上面的例子基本上展示了怎樣使用返回行的相關(guān)性順序漸弱的MATCH()函數(shù)。而下面的例子則展示了怎樣明確地檢索相關(guān)值。返回行的順序是不定的,原因是  SELECT 語句不包含 WHERE或ORDER BY 子句:

mysql> SELECT id, MATCH (title,body) AGAINST ('Tutorial')
    -> FROM articles;
+----+-----------------------------------------+
| id | MATCH (title,body) AGAINST ('Tutorial') |
+----+-----------------------------------------+
|  1 |                        0.65545833110809 |
|  2 |                                       0 |
|  3 |                        0.66266459226608 |
|  4 |                                       0 |
|  5 |                                       0 |
|  6 |                                       0 |
+----+-----------------------------------------+
6 rows in set (0.00 sec)

下面的例子則更加復雜。詢問返回相關(guān)值,同時對行按照相關(guān)性漸弱的順序進行排序。為實現(xiàn)這個結(jié)果,你應(yīng)該兩次指定 MATCH(): 一次在 SELECT 列表中而另一次在 WHERE子句中。這不會引起額外的內(nèi)務(wù)操作,原因是MySQL 優(yōu)化程序注意到兩個MATCH()調(diào)用是相同的,從而只會激活一次全文搜索代碼。

mysql> SELECT id, body, MATCH (title,body) AGAINST
    -> ('Security implications of running MySQL as root') AS score
    -> FROM articles WHERE MATCH (title,body) AGAINST
    -> ('Security implications of running MySQL as root');
+----+-------------------------------------+-----------------+
| id | body                                | score           |
+----+-------------------------------------+-----------------+
|  4 | 1. Never run mysqld as root. 2. ... | 1.5219271183014 |
|  6 | When configured properly, MySQL ... | 1.3114095926285 |
+----+-------------------------------------+-----------------+
2 rows in set (0.00 sec)

表中有2行(0.00 秒)

MySQL FULLTEXT 執(zhí)行將任何單字字符原形 (字母、數(shù)字和下劃線部分)的序列視為一個單詞。這個序列或許也包含單引號 ('),但在一行中不會超過一個。 這意味著 aaa'bbb 會被視為一個單詞,而 aaa''bbb則被視為2個單詞。位于單詞之前或其后的單引號會被FULLTEXT分析程序去掉; 'aaa'bbb' 會變成   aaa'bbb。

FULLTEXT分析程序會通過尋找某些分隔符來確定單詞的起始位置和結(jié)束位置,例如' ' (間隔符號)、 , (逗號)以及 . (句號 )。假如單詞沒有被分隔符分開,(例如在中文里 ), 則 FULLTEXT 分析程序不能確定一個詞的起始位置和結(jié)束位置。為了能夠在這樣的語言中向FULLTEXT 索引添加單詞或其它編入索引的術(shù)語,你必須對它們進行預(yù)處理,使其被一些諸如"之類的任意分隔符分隔開。

一些詞在全文搜索中會被忽略:

◆ 任何過于短的詞都會被忽略。 全文搜索所能找到的詞的默認最小長度為 4個字符。

◆ 停止字中的詞會被忽略。禁用詞就是一個像“the” 或“some” 這樣過于平常而被認為是不具語義的詞。存在一個內(nèi)置的停止字, 但它可以通過用戶自定義列表被改寫。

詞庫和詢問中每一個正確的單詞根據(jù)其在詞庫和詢問中的重要性而被衡量。  通過這種方式,一個出現(xiàn)在許多文件中的單詞具有較低的重要性(而且甚至很多單詞的重要性為零),原因是在這個特別詞庫中其語義價值較低。反之,假如這個單詞比較少見,那么它會得到一個較高的重要性。然后單詞的重要性被組合,從而用來計算該行的相關(guān)性。

這項技術(shù)最適合同大型詞庫一起使用 (事實上, 此時它經(jīng)過仔細的調(diào)整 )。對于很小的表,單詞分布并不能充分反映它們的語義價值, 而這個模式有時可能會產(chǎn)生奇特的結(jié)果。例如, 雖然單詞 “MySQL” 出現(xiàn)在文章表中的每一行,但對這個詞的搜索可能得不到任何結(jié)果:

mysql> SELECT * FROM articles
    -> WHERE MATCH (title,body) AGAINST ('MySQL');

找不到搜索的詞(0.00 秒)

這個搜索的結(jié)果為空,原因是單詞 “MySQL” 出現(xiàn)在至少全文的50%的行中。 因此, 它被列入停止字。對于大型數(shù)據(jù)集,使用這個操作最合適不過了----一個自然語言問詢不會從一個1GB 的表每隔一行返回一次。對于小型數(shù)據(jù)集,它的用處可能比較小。

一個符合表中所有行的內(nèi)容的一半的單詞查找相關(guān)文檔的可能性較小。事實上, 它更容易找到很多不相關(guān)的內(nèi)容。我們都知道,當我們在因特網(wǎng)上試圖使用搜索引擎尋找資料的時候,這種情況發(fā)生的頻率頗高。可以推論,包含該單詞的行因其所在特別數(shù)據(jù)集 而被賦予較低的語義價值。 一個給定的詞有可能在一個數(shù)據(jù)集中擁有超過其50%的域值,而在另一個數(shù)據(jù)集卻不然。

當你***次嘗試使用全文搜索以了解其工作過程時,這個50% 的域值提供重要的蘊涵操作:若你創(chuàng)建了一個表,并且只將文章的1、2行插入其中, 而文中的每個單詞在所有行中出現(xiàn)的機率至少為  50% 。那么結(jié)果是你什么也不會搜索到。一定要插入至少3行,并且多多益善。需要繞過該50% 限制的用戶可使用布爾搜索代碼。

【編輯推薦】

  1. 如何選擇合適的MySQL存儲引擎
  2. MySQL 6.0新特性展望 多項功能增強
  3. MySQL中的字符串比較函數(shù)
責任編輯:楊鵬飛 來源: 網(wǎng)絡(luò)轉(zhuǎn)載
相關(guān)推薦

2018-08-22 14:25:42

搜索LuceneQuery

2025-01-06 09:03:41

2009-02-25 13:59:57

布爾全文搜索全文搜索內(nèi)置函數(shù)

2010-06-11 17:00:34

2025-09-03 08:14:53

2009-08-25 09:44:10

Windows 7虛擬磁盤管理

2010-06-10 13:54:10

MySQL全文搜索

2011-05-16 13:24:00

MySQL全文搜索效率

2010-02-25 21:28:04

2020-06-10 08:23:44

JavaScript開發(fā)Web

2025-02-05 07:26:45

2022-03-22 15:20:32

微信全文搜索

2010-11-25 14:56:46

MySQL全文查詢

2021-06-05 21:29:53

數(shù)據(jù)庫MySQL函數(shù)

2021-10-08 08:58:35

MySQL函數(shù)脫敏

2012-05-10 15:41:46

HTML5

2009-11-10 17:22:23

VB.NET Form

2009-02-24 16:17:41

日期時間函數(shù)

2009-08-14 11:24:10

MySQL全文檢索MySQL Like索

2015-04-03 11:23:11

JavaScript全文搜索相關(guān)度評分
點贊
收藏

51CTO技術(shù)棧公眾號

www.精品国产| 日本波多野结衣在线| 国产精品99在线观看| 欧美一级免费观看| 日日摸日日碰夜夜爽无码| 免费成人av电影| 麻豆高清免费国产一区| 欧美激情亚洲综合一区| 国产jk精品白丝av在线观看| 久久久久九九精品影院| 日韩欧美中文第一页| 一区不卡字幕| 午夜国产在线视频| 精品综合久久久久久8888| 97激碰免费视频| 欧美aaa级片| 女同一区二区三区| 欧美福利电影网| 国产精品999视频| 麻豆tv在线| 91免费国产在线| 亚洲综合中文字幕在线| 久久久久99精品成人片我成大片| 中国精品18videos性欧美| 亚洲欧洲高清在线| 妖精视频在线观看| 成人mm视频在线观看| 亚洲成人综合视频| 偷拍盗摄高潮叫床对白清晰| 黄色电影免费在线看| 成人精品视频.| 成人免费在线视频网站| 无码任你躁久久久久久久| 国产精品成人一区二区网站软件| 色综合伊人色综合网站| 成人精品在线观看视频| 黄色网一区二区| 日韩精品一区二区在线| 女人高潮一级片| 日韩经典一区| 日本乱码高清不卡字幕| 又粗又黑又大的吊av| 国产美女一区视频| 亚洲综合成人在线| 成年人网站国产| 欧美人与动牲性行为| 亚洲人成网站在线| 亚洲欧美99| 2019中文字幕在线视频| 国产精品丝袜一区| 亚洲激情电影在线| 97视频精彩视频在线观看| 国产日韩影视精品| 天堂社区 天堂综合网 天堂资源最新版| 四虎影视精品成人| 91亚洲精品乱码久久久久久蜜桃 | 国产亚洲1区2区3区| 精品国产一区二区三区四区精华| 欧美特黄一级视频| 成人不卡免费av| 国产伦精品一区二区三区四区免费| 性猛交富婆╳xxx乱大交天津| 国产成人久久精品77777最新版本| 亚洲精品欧美日韩专区| 国产免费久久久| 丁香婷婷综合激情五月色| 国产区日韩欧美| 日本啊v在线| 欧美激情在线一区二区三区| 亚洲图片小说在线| 菠萝蜜视频国产在线播放| 亚洲精品成人天堂一二三| 日韩激情视频一区二区| 交100部在线观看| 色偷偷成人一区二区三区91| 三级a在线观看| 电影91久久久| 精品国产凹凸成av人网站| 久久精品综合视频| 国产91精品对白在线播放| 宅男66日本亚洲欧美视频| www.av免费| 亚洲免费高清| 国产精品美女免费| www日本视频| 91亚洲午夜精品久久久久久| 亚洲欧洲一二三| 免费电影网站在线视频观看福利| 欧美日韩日本国产| 中文av一区二区三区| 亚洲精选av| 国产亚洲视频中文字幕视频| 182在线观看视频| 一本一本久久| 成人在线视频网站| 婷婷色在线观看| 国产精品看片你懂得| 久久99久久久久久| av在线不卡精品| 欧美精品一区二区三区久久久| 精品人妻无码一区二区三区| 91精品国产91久久久久久密臀 | 国产一区二区免费| 国产精品成人免费观看| 天使萌一区二区三区免费观看| 91日本在线观看| 深夜福利在线观看直播| 亚洲欧美日韩国产手机在线| 国产亚洲天堂网| 天堂精品在线视频| 国产亚洲美女精品久久久| 精品无码人妻一区二区三区 | 国产成人强伦免费视频网站| 日韩母乳在线| 免费97视频在线精品国自产拍| 午夜婷婷在线观看| 丁香亚洲综合激情啪啪综合| 中文字幕在线亚洲精品 | 黑人巨大精品欧美一区二区三区| 日本77777| 国产成人精品999在线观看| 欧美日韩爱爱视频| 国产乱码精品一区二区| 国产无人区一区二区三区| 天堂…中文在线最新版在线| 国产一区二区三区视频在线| 在线视频欧美性高潮| 天天干天天干天天干天天| 成人一二三区视频| 美女av免费观看| 9999在线精品视频| 日韩中文字幕免费看| 国产一级片av| 久久久久综合网| 久久久亚洲精品无码| 综合中文字幕| 欧美成人中文字幕| 性生活黄色大片| 亚洲激情自拍偷拍| 91欧美一区二区三区| 91视频一区| 国产欧美在线视频| 幼a在线观看| 欧美日韩美女一区二区| 亚洲精品视频网址| 麻豆精品久久精品色综合| 任我爽在线视频精品一| 欧美色网在线| 在线视频欧美日韩| ,一级淫片a看免费| 亚洲欧美日韩小说| 特种兵之深入敌后| 国产综合久久| 高清国语自产拍免费一区二区三区| 在线观看三级视频| 精品国产成人系列| 97久久久久久久| 国产亚洲欧洲一区高清在线观看| 成人一级片网站| av一区二区高清| 国产一区二区色| 精品176二区| 精品久久一二三区| 日韩av免费网址| 久久久99精品久久| 午夜两性免费视频| 亚洲自拍偷拍网| 国产精品国产一区二区| 美女av在线免费看| 亚洲午夜未满十八勿入免费观看全集| 久久精品五月天| 亚洲欧美综合另类在线卡通| 日本少妇一级片| 免费视频一区二区三区在线观看| 日韩欧美激情一区二区| 91麻豆精品国产综合久久久 | 国产亚洲视频在线观看| 97人妻精品一区二区三区| 亚洲一区在线观看免费 | 91欧美日韩| 国产精品推荐精品| 欧美一级二级视频| 欧美久久精品一级黑人c片 | 夜夜狠狠擅视频| 亚洲一区二区三区爽爽爽爽爽 | 不卡av中文字幕| 欧美日韩视频在线| 女性裸体视频网站| 不卡av在线免费观看| 香蕉视频禁止18| 国内一区二区三区| 先锋在线资源一区二区三区| 亚洲国产欧美国产第一区| 欧美一级淫片丝袜脚交| 国产激情在线| 亚洲欧美日本精品| www.久久成人| 91国模大尺度私拍在线视频| 老司机成人免费视频| av午夜一区麻豆| 亚洲妇熟xx妇色黄蜜桃| 亚洲欧美激情诱惑| 日韩欧美一级在线| 久久不见久久见免费视频7| 亚洲综合在线小说| 久久精品xxxxx| 欧美亚洲成人网| 成人av福利| 综合网中文字幕| 婷婷视频在线观看| 欧美va天堂va视频va在线| 中文字幕永久在线观看| 精品福利在线观看| 久久久久亚洲av无码专区体验| 久久精品亚洲精品国产欧美 | 日韩精品dvd| 激情欧美一区二区三区中文字幕| 大胆国模一区二区三区| 国产精品免费一区| 成人软件在线观看| 66m—66摸成人免费视频| 三级资源在线| 欧美xxxx综合视频| 求av网址在线观看| 在线观看精品自拍私拍| 免费理论片在线观看播放老| 精品国产亚洲在线| 国产超碰人人模人人爽人人添| 欧美三级在线看| 无码人妻久久一区二区三区不卡| 午夜精品爽啪视频| 国产午夜福利片| 一区二区成人在线| 国产盗摄x88av| 亚洲精品视频免费观看| 日韩欧美国产成人精品免费| 国产精品乱码人人做人人爱 | 欧美精品97| 粉嫩av一区二区三区天美传媒| 久久香蕉国产| 亚洲一二三区精品| 国产高清一区| 久久精品国产精品亚洲精品色| 欧美电影《轻佻寡妇》| 亚洲欧美日韩国产成人综合一二三区 | a91a精品视频在线观看| 青青草成人免费在线视频| 亚洲婷婷免费| 缅甸午夜性猛交xxxx| 亚洲一区二区三区四区五区午夜 | 九一九一国产精品| 99九九精品视频| 国产精品一级片| 色诱av手机版| www.欧美日韩| 国产艳俗歌舞表演hd| 国产欧美一区二区精品性色超碰| 欧美做受xxxxxⅹ性视频| 亚洲国产成人在线| 美国精品一区二区| 亚洲精品网站在线观看| 国产一级片免费| 欧美日韩激情网| 无码人妻精品一区二| 欧美日韩精品欧美日韩精品一| 91免费视频播放| 欧美大胆人体bbbb| 无码国产精品96久久久久| 亚洲免费中文字幕| a√资源在线| 欧美成人免费大片| 第一福利在线视频| 国产精品99一区| 国产一区影院| 国产精品对白刺激久久久| 天海翼亚洲一区二区三区| 色一情一乱一伦一区二区三区 | 欧洲精品在线视频| 国产精品久久久久77777丨| 亚洲xxx自由成熟| 日韩精品福利一区二区三区| 亚洲成人自拍视频| 欧美精品97| 午夜视频你懂的| 国产一区二区精品久久| 欧美无人区码suv| 国产精品美女久久福利网站| 免看一级a毛片一片成人不卡| 欧美午夜久久久| 99久久夜色精品国产亚洲| 日韩av综合中文字幕| 蜜桃av在线免费观看| 国产+人+亚洲| 欧美a视频在线| 精品国产乱码久久久久久丨区2区| 色综合蜜月久久综合网| 欧洲精品一区二区三区久久| 麻豆精品视频在线观看视频| 在线精品一区二区三区| |精品福利一区二区三区| 日韩欧美三级在线观看| 91精品在线麻豆| 国产免费a∨片在线观看不卡| 欧美另类极品videosbestfree| 成人美女大片| 成人性色av| 小说区亚洲自拍另类图片专区| 日韩人妻精品无码一区二区三区| 国产精选一区二区三区| www色com| 日韩欧美成人精品| 天堂网在线观看视频| 美女国内精品自产拍在线播放| 韩国精品主播一区二区在线观看| 国产精品视频在线免费观看| 在线精品国产| 久久人人爽av| 国产亚洲欧美激情| 五月天婷婷激情| 精品av久久707| 2024最新电影免费在线观看| 国产精品一区av| 国内精品视频在线观看| 国产免费一区二区三区视频| 菠萝蜜视频在线观看一区| 久久久一二三区| 欧美一区国产二区| 免费在线你懂的| 国产精品自在线| 日韩免费一区| 邪恶网站在线观看| 国产精品天天摸av网| 免费一级a毛片| 亚洲一级一级97网| 日本欧美日韩| 日韩av在线一区二区三区| 国产欧美二区| 久久性爱视频网站| 性做久久久久久| 少妇精品视频一区二区 | 女同性恋一区二区| 精品中文字幕一区二区| 夫妻性生活毛片| 欧美一级免费大片| 久草在线资源站资源站| 国产高清精品一区二区| 伊人久久婷婷| 波多野结衣有码| 欧美午夜视频在线观看| 青青草手机在线| 国产精品久久久久久av福利软件 | 91视频免费版污| 亚洲国产精品av| 亚洲中文字幕一区二区| www.日韩.com| 日韩免费成人| 性欧美大战久久久久久久| 91在线porny国产在线看| 无码人妻av免费一区二区三区| 国产亚洲视频中文字幕视频| 欧美成人xxxx| 人人妻人人澡人人爽欧美一区| 国产成人自拍网| 日韩一区二区视频在线| 亚洲三级 欧美三级| 日韩精品一级毛片在线播放| 看一级黄色录像| 成人白浆超碰人人人人| 欧美一区二区三区久久久| 日韩在线视频免费观看| 亚洲综合网狠久久| 国产精品无码av在线播放| 久久九九久久九九| 91国内精品视频| 久久久久久久香蕉网| 欧美美女在线观看| 亚洲第一天堂久久| 亚洲午夜精品17c| 国产人成在线观看| aaa级精品久久久国产片| 欧美亚洲在线| 91 在线视频| 亚洲精品日韩丝袜精品| 最新亚洲国产| 久久国产成人精品国产成人亚洲| 亚洲国产高清在线观看视频| 精品女同一区二区三区| 欧美性受xxxx黑人猛交| 久久久久免费av| 中文字幕一区二区三区人妻电影| 在线电影国产精品| 正在播放日韩精品| 亚洲自拍偷拍一区二区三区| 91在线国产观看| av免费在线观看不卡| 日本精品视频在线播放| 最新精品国产| 亚洲黄色网址大全| 亚洲精品v欧美精品v日韩精品| 四虎国产精品免费久久5151|