在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