SQL的LIKE查询语句中,有一些特殊的字符,需要转换后才能搜索到结果: ':用于包裹搜索条件,需转为\'; %:用于代替任意数目的任意字符,需转换为\%; _:用于代替一个任意字符,需转换为\_; \:转义符号,需转换为\\\\。 以下是一些匹配的举例。 SELECT * FROM `table` WHERE `title` LIKE 'a\'b%'; -- 搜索a'b... SELECT * FROM `table` WHERE `title` LIKE 'a\%b%'; -- 搜索a%b... SELECT * FROM `table` WHERE `title` LIKE 'a\_b%'; -- 搜索a_b... SELECT * FROM `table` WHERE `title` LIKE 'a\\\\%'; -- 搜索a\b... 在PHP代码中,可以用这样的方法批量替换: function filterLike($keyword) { $search = array('\'', '%', '_', '\\'); $replace = array('\\\'', '\\%', '\\_', '\\\\\\\\'); return str_replace($search, $replace, $keyword); } |
Archiver|手机版|笨鸟自学网 ( 粤ICP备20019910号 )
GMT+8, 2024-11-21 23:03 , Processed in 0.033459 second(s), 18 queries .