3

是否可以强制查询区分大小写?

我的声音是这样的:

"SELECT g_path FROM glyphs WHERE g_glyph = :g_glyph ORDER BY rand()"

如果 g_glyph = r,则结果可以是 R 或 r,这不是我所期望的。我正在寻找区分大小写的返回。

我用谷歌搜索了我的问题,我找到了这个解决方案:

/*Case-sensitive sort in descending order.
In this query, ProductName is sorted in 
case-sensitive descending order.
*/
SELECT ProductID, ProductName, UnitsInStock
FROM products
ORDER BY BINARY ProductName DESC;

但是以下行根本不起作用:

"SELECT g_path FROM glyphs WHERE g_glyph = :g_glyph ORDER BY BINARY rand()"

有什么建议吗?

非常感谢您的帮助。

4

2 回答 2

5

字符的顺序和相等性由排序规则定义。在大多数情况下,使用不区分大小写的排序规则。

如果您需要对特定数据使用严格、区分大小写的比较,请使用BINARY运算符

mysql> SELECT 'a' = 'A';
        -> 1
mysql> SELECT BINARY 'a' = 'A';
        -> 0
mysql> SELECT 'a' = 'a ';
        -> 1
mysql> SELECT BINARY 'a' = 'a ';
        -> 0

所以在你的情况下:

SELECT g_path FROM glyphs WHERE BINARY g_glyph = :g_glyph ORDER BY rand()
于 2012-04-15T08:42:39.420 回答
2

手册页Case Sensitivity in String Searches对此进行了介绍。

您需要指定区分大小写或二进制排序规则。

默认字符集和排序规则是 latin1 和 latin1_swedish_ci,因此默认情况下非二进制字符串比较不区分大小写。这意味着如果您使用 col_name LIKE 'a%' 进行搜索,您将获得所有以 A 或 a 开头的列值。要使此搜索区分大小写,请确保其中一个操作数具有区分大小写或二进制排序规则。例如,如果要比较都具有 latin1 字符集的列和字符串,则可以使用 COLLATE 运算符使任一操作数具有 latin1_general_cs 或 latin1_bin 排序规则:

col_name COLLATE latin1_general_cs LIKE 'a%'
col_name LIKE 'a%' COLLATE latin1_general_cs
col_name COLLATE latin1_bin LIKE 'a%'
col_name LIKE 'a%' COLLATE latin1_bin

如果您希望始终以区分大小写的方式处理列,请使用区分大小写或二进制排序规则声明它。请参见第 13.1.14 节,“CREATE TABLE 语法”。

排序规则名称中的_cs代表“区分大小写”。

于 2012-04-15T08:28:16.717 回答