日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

Mysql FULLTEXT索引说明 | 草根程序猿

發(fā)布時間:2024/8/24 综合教程 27 生活家
生活随笔 收集整理的這篇文章主要介紹了 Mysql FULLTEXT索引说明 | 草根程序猿 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

Mysql FULLTEXT索引說明 | 草根程序猿

FULL TEXT索引 Mysql 3.23.23以及更高版本支持一種特殊類型的索引 全文索引在 MySQL 中是一個 全文索引在 MySQL 中是一個 FULLTEXT 類型索引。FULLTEXT 索引用于 MyISAM 表(且僅支持該類型的表),可以在 CREATE TABLE 時或之后使用 ALTER TABLECREATE INDEXCHARVARCHARTEXT 列上創(chuàng)建。對于大的數(shù)據(jù)庫,將數(shù)據(jù)裝載到一個沒有 FULLTEXT 索引的表中,然后再使用 ALTER TABLE (或 CREATE INDEX) 創(chuàng)建索引,這將是非常快的。將數(shù)據(jù)裝載到一個已經(jīng)有 FULLTEXT 索引的表中,將是非常慢的。

全文搜索通過 MATCH() 函數(shù)完成。

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 VALUES
    -> (NULL,'MySQL Tutorial', 'DBMS stands for DataBase ...'),
    -> (NULL,'How To Use MySQL Efficiently', 'After you went through a ...'),
    -> (NULL,'Optimising MySQL','In this tutorial we will show ...'),
    -> (NULL,'1001 MySQL Tricks','1. Never run mysqld as root. 2. ...'),
    -> (NULL,'MySQL vs. YourSQL', 'In the following database comparison ...'),
    -> (NULL,'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)

函數(shù) MATCH() 對照一個文本集(包含在一個 FULLTEXT 索引中的一個或多個列的列集)執(zhí)行一個自然語言搜索一個字符串。搜索字符串做為 AGAINST() 的參數(shù)被給定。搜索以忽略字母大小寫的方式執(zhí)行。對于表中的每個記錄行,MATCH() 返回一個相關(guān)性值。即,在搜索字符串與記錄行在 MATCH() 列表中指定的列的文本之間的相似性尺度。
如果即沒有 WHERE 也沒有 ORDER BY 子句,返回行是不排序的。 
下一個示例顯示如何檢索一個明確的相似性值
mysql> SELECT id,MATCH (title,body) AGAINST ('Tutorial') FROM articles;
+----+-----------------------------------------+
| id | MATCH (title,body) AGAINST ('Tutorial') |
+----+-----------------------------------------+
|  1 |                        0.64840710366884 |
|  2 |                                       0 |
|  3 |                        0.66266459031789 |
|  4 |                                       0 |
|  5 |                                       0 |
|  6 |                                       0 |
+----+-----------------------------------------+
6 rows in set (0.00 sec)

到 4.0.1 時,MySQL 也可以使用 IN BOOLEAN MODE 修飾語來執(zhí)行一個邏輯全文搜索。

mysql> SELECT * FROM articles WHERE MATCH (title,body)
    ->     AGAINST ('+MySQL -YourSQL' IN BOOLEAN MODE);
+----+------------------------------+-------------------------------------+
| id | title                        | body                                |
+----+------------------------------+-------------------------------------+
|  1 | MySQL Tutorial               | DBMS stands for DataBase ...        |
|  2 | How To Use MySQL Efficiently | After you went through a ...        |
|  3 | Optimising MySQL             | In this tutorial we will show ...   |
|  4 | 1001 MySQL Tricks            | 1. Never run mysqld as root. 2. ... |
|  6 | MySQL Security               | When configured properly, MySQL ... |
+----+------------------------------+-------------------------------------+

這個查詢返回所有包含詞 MySQL 的記錄行(注意: 50% 的閾值沒有使用),但是它沒有包含詞 YourSQL。注意,一個邏輯模式的搜索不會自動地以相似值的降序排序記錄行。你可以從上面的結(jié)果出看得出來,最高的相似值(包含 MySQL 兩次的那個) 最列在最后,而不是第一位。一個邏輯全文搜索即使在沒有一個 FULLTEXT 索引的情況下也可以工作,然而它 些。

邏輯全文搜索支持下面的操作符:

+ 一個領(lǐng)頭的加號表示,該詞必須出現(xiàn)在每個返回的記錄行中。 - 一個領(lǐng)頭的減號表示,該詞必須不出現(xiàn)在每個返回的記錄行中。 缺省的 (當(dāng)既沒有加號也沒有負(fù)號被指定時)詞是隨意的,但是包含它的記錄行將被排列地更高一點。這個模仿沒有 IN BOOLEAN MODE 修飾詞的 MATCH() ... AGAINST() 的行為。 < > 這兩個操作符用于改變一個詞的相似性值的基值。< 操作符減少基值,> 操作符則增加它。參看下面的示例。 ( ) 圓括號用于對子表達式中的詞分組。 ~ 一個領(lǐng)頭的否定號的作用象一個否定操作符,引起行相似性的詞的基值為負(fù)的。它對標(biāo)記一個噪聲詞很有用。一個包含這樣的詞的記錄將被排列得低一點,但是不會被完全的排除,因為這樣可以使用 - 操作符。 * 一個星號是截斷操作符。不想其它的操作符,它應(yīng)該被追加到一個詞后,不加在前面。 " 短語,被包圍在雙引號"中,只匹配包含這個短語(字面上的,就好像被鍵入的)的記錄行。

這里是一些示例:

apple banana 找至少包含上面詞中的一個的記錄行 +apple +juice ... 兩個詞均在被包含 +apple macintosh ... 包含詞 “apple”,但是如果同時包含 “macintosh”,它的排列將更高一些 +apple -macintosh ... 包含 “apple” 但不包含 “macintosh” +apple +(>pie <strudel) ... 包含 “apple” 和 “pie”,或者包含的是 “apple” 和 “strudel” (以任何次序),但是 “apple pie” 排列得比 “apple strudel” 要高一點 apple* ... 包含 “apple”,“apples”,“applesauce” 和 “applet” "some words" ... 可以包含 “some words of wisdom”,但不是 “some noise words”

總結(jié)

以上是生活随笔為你收集整理的Mysql FULLTEXT索引说明 | 草根程序猿的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。