mariadb 版本10.4
$query->where('column', 'REGEXP', '[[:<:]]'.$string.'[[:>:]]');
此查询仅提供整个单词的搜索,并且在没有特殊字符的情况下可以正常工作。
例子
搜索行:
foo (bar baz)
筛选:
$string = "(bar";
$query->where('column', 'REGEXP', '[[:<:]]'.$string.'[[:>:]]');
错误:
SQLSTATE[42000]: Syntax error or access violation: 1139 Got error 'missing )
现在我尝试使用addcslashesand preg_quote。我成功地转义(了字符,preg_quote但过滤器不适用于该字符串,因为过滤器适用于整个单词。
任何通过整个单词更好地过滤的建议也将不胜感激。
再举一个例子
搜索行:
foo(bar baz
筛选:
$filter = 'foo(bar';
$query->where('column', 'REGEXP', '[[:<:]]'.$string.'[[:>:]]');
如果(将被转义,则搜索将不起作用