我怎样才能逃脱Laravel/Elount中的LIKE
条款?例如.,
$search = Input::query('sSearch', '');
if($search !== '') {
$paginatedBookings->where('first_name', 'LIKE', '%' . $search . '%');
}
如果$search
包含%
或_
,则需要对其进行转义.
我怎样才能逃脱Laravel/Elount中的LIKE
条款?例如.,
$search = Input::query('sSearch', '');
if($search !== '') {
$paginatedBookings->where('first_name', 'LIKE', '%' . $search . '%');
}
如果$search
包含%
或_
,则需要对其进行转义.
另一个答案忘记了转义字符本身,下面是一个更健壮的解决方案:
/**
* Escape special characters for a LIKE query.
*
* @param string $value
* @param string $char
*
* @return string
*/
function escape_like(string $value, string $char = '\\'): string
{
return str_replace(
[$char, '%', '_'],
[$char.$char, $char.'%', $char.'_'],
$value
);
}