笨鸟编程-零基础入门Pyhton教程

 找回密码
 立即注册
笨鸟先学早入门,一分付出一分收获

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

}

最新评论

Archiver|手机版|笨鸟自学网 ( 粤ICP备20019910号 )

GMT+8, 2024-11-21 23:03 , Processed in 0.033459 second(s), 18 queries .

© 2001-2020

返回顶部