四时宝库

程序员的知识宝库

MySQL用LIKE特殊字符搜索(mysql like 字段)

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);

}

发表评论:

控制面板
您好,欢迎到访网站!
  查看权限
网站分类
最新留言
    友情链接