有人能告诉我,如果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是大多数数据库中常见或默认的排序规则。
其他回答
带有二进制标志设置的字符串字段将始终区分大小写。 如果你需要对非二进制文本字段进行区分大小写的搜索,请使用以下方法: SELECT 'test' REGEXP二进制'test'作为结果;
您选择的排序规则集是否区分大小写。
您可以小写的值和传递的参数:
SELECT * FROM `table` WHERE LOWER(`Value`) = LOWER("IAreSavage")
另一种(更好的)方法是使用文档中提到的COLLATE操作符
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是大多数数据库中常见或默认的排序规则。
你可以试试。 希望对大家有用。
SELECT * FROM `table` WHERE `Value` COLLATE latin1_general_cs = "IAreSavage"