開發過程中碰到一個關於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')