MySQL用LIKE特殊字符搜索

"本文介绍了在SQL的LIKE语句中如何处理和转义特殊字符,包括'、%、_和。给出了PHP函数filterLike()用于批量替换这些特殊字符的例子,以确保正确执行LIKE查询。通过理解这些转义规则,开发者可以更有效地进行数据过滤和搜索操作。"
摘要由CSDN通过智能技术生成

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

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值