開發過程中碰到一個關於mysql 全文檢索的問題,控制台打印的SQL語句拿到數據庫裡執行,結果不對。後來發現原來是少了雙引號。下面是網上找到的資料,我是看到這個才意識到自己的問題。
這是之前在數據庫執行的SQL語句,檢索結果上萬條。
SELECT DISTINCT c.Rm_Code, c.Tsr_Code, c.TradeName, c.Location, c.Tel_Number, c.Url, c.Nss_category1, c.Nss_category2 FROM CompanyMst c INNER JOIN Tradename_keyword t ON t.rm_code = c.rm_code WHERE c.Show_flag = 0 AND MATCH(t.keyword_unicode)AGAINST( '30d1 30bd 30ca ' IN BOOLEAN MODE ) ORDER BY LstEntDtm DESC, Rm_Code ASC
這是之後改正後在數據庫執行的SQL語句,檢索結果11條。
SELECT DISTINCT c.Rm_Code, c.Tsr_Code, c.TradeName, c.Location, c.Tel_Number, c.Url, c.Nss_category1, c.Nss_category2 FROM CompanyMst c INNER JOIN Tradename_keyword t ON t.rm_code = c.rm_code WHERE c.Show_flag = 0 AND MATCH(t.keyword_unicode)AGAINST( '"30d1 30bd 30ca "' IN BOOLEAN MODE ) ORDER BY LstEntDtm DESC, Rm_Code ASC
[(]
[)]
特殊符號用中括號括起來就是原意,同理還有[-]等
這個簡單
alter table `tmp` add fulltext(`column_1`,`column_2`....); /***添加**/
//查詢
select * from `tmp` where match(`column_1`,`column_2`) against('$key')