我正在尝试从mysql表中选择一些数据,但是我不能让Where比较不区分大小写,我尝试使用LOWER:
$wildcard = $_GET['q'];
$query = "SELECT id, name, departamento FROM gestionDoc_cargos WHERE (LOWER(name) LIKE '%' LOWER(:wildcard) '%' OR LOWER(departamento) LIKE '%' LOWER(:wildcard) '%')";
try{
$result = DB::getInstance()->prepare($query);
$result->bindParam(':wildcard', $wildcard, PDO::PARAM_STR);
$result->execute();
$result = $result->fetchAll(PDO::FETCH_ASSOC);
}catch(PDOException $e){
die($e->getMessage());
}
print_r($result);
echo json_encode(array_values($result));
但是我收到以下错误:
SQLSTATE[42000]: Syntax error or access violation: 1064 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'LOWER('C') '%' OR LOWER(departamento) LIKE '%' LOWER('C') '%')' at line 1
如果我从查询中删除LOWER,我会得到区分大小写的选择。
答案 0 :(得分:1)
此
...snip... ) LIKE '%' LOWER(:wildcard) '%' OR ...snip
不正确。你有一个字符串('%'
)后跟一个函数调用(LOWER()
)后跟另一个字符串,它们只是坐在那里 - 没有连接逻辑,没有连接,等等等等。 / p>
应该是
... LIKE CONCAT('%', LOWER(:wildcard), '%') OR ...
默认情况下,mysql比较不区分大小写,除非您强制执行binary
比较,或者您在db / table上使用区分大小写的排序规则。