有人能告诉我,如果MySQL SELECT查询是大小写敏感或大小写不敏感默认?如果不是,我要发送什么查询,这样我就可以做一些事情:
SELECT * FROM `table` WHERE `Value` = "iaresavage"
实际上,价值的真正价值是IAreSavage。
有人能告诉我,如果MySQL SELECT查询是大小写敏感或大小写不敏感默认?如果不是,我要发送什么查询,这样我就可以做一些事情:
SELECT * FROM `table` WHERE `Value` = "iaresavage"
实际上,价值的真正价值是IAreSavage。
当前回答
WHERE短语中的字符串比较不区分大小写。你可以试着比较使用
WHERE `colname` = 'keyword'
or
WHERE `colname` = 'KeyWord'
你会得到同样的结果。这是MySQL的默认行为。
如果你想让比较区分大小写,你可以添加COLLATE,就像这样:
WHERE `colname` COLLATE latin1_general_cs = 'KeyWord'
SQL会给出不同的结果: WHERE colname COLLATE latin1_general_cs = '关键字'
Latin1_general_cs是大多数数据库中常见或默认的排序规则。
其他回答
默认是不区分大小写的,但是 下一个最重要的事情 您应该看看该表是如何创建的 首先,因为你可以指定大小写 创建表时的敏感性。
下面的脚本创建一个表。 注意在底部,它说COLLATE latin1_general_cs。 结尾的cs表示区分大小写。 如果你想要 表是不区分大小写的,你要么保留它 或者使用“COLLATE latin1_general_ci”。
CREATE Table PEOPLE (
USER_ID INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
FIRST_NAME VARCHAR(50) NOT NULL,
LAST_NAME VARCHAR(50) NOT NULL,
PRIMARY KEY (USER_ID)
)
ENGINE=MyISAM DEFAULT CHARACTER SET latin1
COLLATE latin1_general_cs AUTO_INCREMENT=0;
如果您的项目是这样的,您可以创建您的 自己的表,那么指定您的 在创建表时选择大小写。
它们是不区分大小写的,除非你做二进制比较。
您选择的排序规则集是否区分大小写。
在我的情况下,二进制或整理或字符集工作与我的UTF8表。
我的表中有用户名,如henry, henry, susan, susan或susan,并通过比较名称的字节序列来查找各自的用户。
下面的函数创建字节序列:
function makeByteString($string){
$tmp = "";
for($i=0;$i<strlen($string);$i++){
$sign = substr($string,$i,1);
$tmp.=ord($sign);
}
return $tmp;
}
SQL查询找到正确的id:
$sql = "SELECT id, username FROM users WHERE `username` = ? ";
$stmt = $conn->prepare($sql);
$stmt->execute([$strUsername]); //e.g. susan, Susan or suSan
$rows = $stmt->rowCount();
if($stmt && $rows>0){
while ($row = $stmt->fetch()) {
if(makeByteString($strUsername) ==
makeByteString(trim($row["username"]))){
$id = $row['id'];
}
}
}
还要注意,在Linux上表名是区分大小写的,除非您将lower_case_table_name config指令设置为1。这是因为在Linux中表是由区分大小写的文件表示的。
尤其要注意在不区分大小写的Windows上开发,并将其部署到生产环境中。例如:
"SELECT * from mytable"
除非设置了上面提到的指令,否则myTable在Windows中会成功,但在Linux中会失败。
参考资料:http://dev.mysql.com/doc/refman/5.0/en/identifier-case-sensitivity.html