1. 程式人生 > >mysql全文索引使用方法

mysql全文索引使用方法

一、設定全文索引
新增:ALTER TABLE table_name ADD FULLTEXT ( column);
刪除:DROP INDEX index_name ON table_name;
注:mysql5.6版本以下只有myisam儲存引擎支援全文索引,mysql5.6以上版本myisam和innodb都支援全文索引,兩者效能有興趣了可以比較一下。
二、搜尋語句
SELECT * FROM table_name WHERE MATCH(index_name) AGAINST(‘搜尋值’);
多詞請用逗號或空格分開:SELECT * FROM table_name WHERE MATCH(index_name) AGAINST(‘a,b’);
到這裡基本已經可以使用了,但是有時候在搜尋單個字元時候沒有結果,這時候需要修改一下全文索引關鍵詞長度設定了。
注:當個別詞的出現頻率超過50%時,被認作無效詞,可以改為AGAINST (‘高頻詞’ IN BOOLEAN MODE)。
三、修改配置


找到mysql.ini,在在 [mysqld] 位置新增:ft_min_word_len=1
重啟mysql服務。
檢視mysql環境變數:show variables;就可以看到設定的結果了
這裡寫圖片描述

注:
1.全文索引的欄位型別必須為:char,varchar,text 。
2.對於中文全文索引,必須先把欄位值做好中文分詞,每個關鍵詞之間用“ ,”“ ”分開,不然即使全文索引還是無效,誰讓這些都是老外開發的呢(英文單詞之間都是空格,妥妥的),但是中文分詞可以藉助其他一些開源程式來做,比如:coreseek,附上下載地址:http://www.coreseek.cn/news/7/52/


3.有人說將中文轉成拼音,然後進行搜尋,或許是一個好的方法,可以試一下。