mysql 字符串查找 开发技巧

lecms 4天前 24

‌在MySQL中,LIKE操作的效率通常低于INSTR函数,尤其是在没有使用索引的情况下。‌ 

LIKE操作符用于模糊匹配字符串,当使用%作为通配符时,会导致全表扫描,从而降低查询效率。

而INSTR函数虽然效率稍高于LIKE,但在大数据量下仍然可能成为性能瓶颈。

 

选择合适的函数‌:

在性能要求较高的场景下,可以考虑使用LOCATE()或FIND_IN_SET(),这些函数的效率通常高于LIKE和INSTR。

 

SELECT * FROM users WHERE FIND_IN_SET('reading', hobbies) > 0;
这条查询语句会返回所有hobbies字段包含reading的记录‌

SELECT * FROM users where LOCATE('aa@email.com',email);

SELECT * FROM users WHERE INSTR(title,'字符串')>0 ORDER BY id DESC LIMT 10

最新回复 (0)
返回
发新帖