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

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

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


当前回答

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

其他回答

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

Marc B的回答基本正确。

如果您使用的是非二进制字符串(CHAR, VARCHAR, TEXT),根据默认排序规则,比较是不区分大小写的。

如果您正在使用二进制字符串(binary, VARBINARY, BLOB),比较是区分大小写的,因此您需要使用LOWER,如其他答案中所述。

如果不使用默认排序规则,而使用非二进制字符串,则大小写敏感性由所选的排序规则决定。

来源:https://dev.mysql.com/doc/refman/8.0/en/case-sensitivity.html。仔细地阅读。还有一些人误解了这一点,认为比较必须区分大小写或不敏感。事实并非如此。

您选择的排序规则集是否区分大小写。

您可以小写的值和传递的参数:

SELECT * FROM `table` WHERE LOWER(`Value`) = LOWER("IAreSavage")

另一种(更好的)方法是使用文档中提到的COLLATE操作符

使用二进制

这是一个简单的选择

SELECT * FROM myTable WHERE 'something' = 'something'

= 1

这是一个二进制选择

SELECT * FROM myTable WHERE BINARY 'something' = 'something'

or

SELECT * FROM myTable WHERE 'something' = BINARY '

= 0