SQL区分大小写吗?我用过MySQL和SQL Server,它们似乎都是不区分大小写的。情况总是这样吗?标准是否定义了区分大小写?


当前回答

我不认为SQL Server是区分大小写的,至少默认情况下不是。

当我通过SQL Server Management Studio手动查询时,我总是搞砸情况,它很高兴地接受它:

select cOL1, col2 FrOM taBLeName WheRE ...

其他回答

这不是严格的SQL语言,但在SQL Server中,如果您的数据库排序是区分大小写的,那么所有表名都是区分大小写的。

我不认为SQL Server是区分大小写的,至少默认情况下不是。

当我通过SQL Server Management Studio手动查询时,我总是搞砸情况,它很高兴地接受它:

select cOL1, col2 FrOM taBLeName WheRE ...

不。MySQL不区分大小写,SQL标准也不区分大小写。通常的做法是将命令写成大写。

现在,如果您谈论的是表/列名,那么是的,它们是,但不是命令本身。

So

SELECT * FROM foo;

select * from foo;

但不一样

select * from FOO;

SQL关键字是不区分大小写的(SELECT, FROM, WHERE等),但它们通常都是大写的。但是,在某些设置中,表名和列名是区分大小写的。

MySQL有一个配置选项来启用/禁用它。通常区分大小写的表和列名是Linux MySQL的默认值,不区分大小写曾经是Windows的默认值,但现在安装程序在安装过程中询问这一点。对于SQL Server,它是数据库排序规则设置的函数。

这里是关于名称区分大小写的MySQL页面

下面是MSDN中关于SQL Server排序规则的文章

标识符和保留词不应该区分大小写,尽管许多标识符遵循一个约定,即保留词使用大写,标识符使用驼峰大小写。

参见SQL-92第5.2节