有人能告诉我,如果MySQL SELECT查询是大小写敏感或大小写不敏感默认?如果不是,我要发送什么查询,这样我就可以做一些事情:

SELECT * FROM `table` WHERE `Value` = "iaresavage"

实际上,价值的真正价值是IAreSavage。


当前回答

还要注意,在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

其他回答

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是大多数数据库中常见或默认的排序规则。

在我的情况下,二进制或整理或字符集工作与我的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'];
    }
  }
}   

SQL Select不区分大小写。

这个链接可以告诉你如何区分大小写:http://web.archive.org/web/20080811231016/http://sqlserver2000.databases.aspfaq.com:80/how-can-i-make-my-sql-queries-case-sensitive.html

还要注意,在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

带有二进制标志设置的字符串字段将始终区分大小写。 如果你需要对非二进制文本字段进行区分大小写的搜索,请使用以下方法: SELECT 'test' REGEXP二进制'test'作为结果;