主页 > MySQL教程 > 正文

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

}


上一篇:MySQL保存几位小数的4种办法
下一篇:最终一页

PythonTab微信大众号:

Python技能交流合作群 ( 请勿加多个群 ):

群1: 87464755

群2: 333646237

群3: 318130924

群4: 385100854