[mysql] 模糊查詢的幾種寫法


目的:mysql模糊查詢優化

	select* from test where name like '%keyword%';

使用like關鍵詞不會用到索引,查詢效率也比較低

優化如下:使用instr,position,locate函數

	SELECT * FROM test  where instr('keyword',name) > 0;

	SELECT * FROM test  where position('keyword' in name) ;

	SELECT * FROM test  where locate('keyword',name) > 0;

除了上述的方法外,還有一個函數FIND_IN_SET(str1,str2),返回str2中str1所在的位置索引,其中str2必須以","分割開。

select * from test where FIND_IN_SET('say',`name`);


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM