SQL中单引号和双引号的区别是什么?
当前回答
在ANSI SQL中,双引号引用对象名称(例如表),允许它们包含其他不允许的字符,或与保留字相同(真的要避免这种情况)。
单引号用于字符串。
然而,MySQL并不关心这个标准(除非它的SQL_MODE被改变了),并且允许它们互换地用于字符串。
此外,Sybase和Microsoft也使用方括号作为标识符引号。
所以这有点特定于供应商。
其他数据库,如Postgres和IBM实际上坚持ansi标准:)
其他回答
单引号分隔字符串常量或日期/时间常量。
双引号分隔标识符,例如表名或列名。这通常只在标识符不符合简单标识符规则时才有必要。
参见:
不同的数据库使用不同的名称引用吗?
你可以让MySQL使用ANSI标准的双引号:
SET GLOBAL SQL_MODE=ANSI_QUOTES
你可以让Microsoft SQL Server使用ANSI标准的双引号:
SET QUOTED_IDENTIFIER ON
一个简单的规则让我们记住在什么情况下使用什么:
[S]单引号用于[S]字符串字面量(日期字面量也是字符串); [D]双引号是数据库标识符;
例子:
INSERT INTO "USERS" ("LOGIN", "PASSWORD", "DT_BIRTH") VALUES ('EDUARDO', '12345678', '1980-09-06');
在MySQL和MariaDB中,'(反标记)符号与"符号相同。注意,当SQL_MODE启用了ANSI_QUOTES时,不能使用“”作为文本字符串。
在ANSI SQL中,双引号引用对象名称(例如表),允许它们包含其他不允许的字符,或与保留字相同(真的要避免这种情况)。
单引号用于字符串。
然而,MySQL并不关心这个标准(除非它的SQL_MODE被改变了),并且允许它们互换地用于字符串。
此外,Sybase和Microsoft也使用方括号作为标识符引号。
所以这有点特定于供应商。
其他数据库,如Postgres和IBM实际上坚持ansi标准:)
要记住两件事:
单个Qutoes('):字符串或文本
select * from employees where room_name = 'RobinCapRed';
其中RobinCapRed是一个字符串或文本。
双引号("):列名或表名
select "first_name" from "employees";
where first_Name是员工表的列名
区别在于它们的用法。单引号主要用于WHERE、HAVING和一些内置SQL函数(如CONCAT、STRPOS、POSITION等)中引用字符串。
当你想使用一个中间有空格的别名时,你可以使用双引号来引用这个别名。
例如
(select account_id,count(*) "count of" from orders group by 1)sub
下面是来自订单表的子查询,其中account_id作为外键,我正在聚合以了解每个帐户下了多少订单。在这里,为了方便起见,我给一列取了任意随机名称“count of”。
现在让我们编写一个外部查询来显示“count of”大于20的行。
select "count of" from
(select account_id,count(*) "count of" from orders group by 1)sub where "count of" >20;
您也可以将相同的情况应用于公共表表达式。
推荐文章
- 在MySQL中检测值是否为number
- MySQL中两个日期之间的差异
- 使用SQL查询查找最近的纬度/经度
- 模式、表和数据库之间的区别是什么?
- 将一列的多个结果行连接为一列,按另一列分组
- 检查MySQL表是否存在而不使用“select from”语法?
- 我看到VARCHAR(255)如此频繁地使用(而不是其他长度),有什么好的原因吗?
- 使用pgadmin连接到heroku数据库
- 在PostgreSQL中快速发现表的行数
- 更改varchar列的大小为较低的长度
- 从表中选择1是什么意思?
- Delete_all vs destroy_all
- 双引号vs单引号
- 我如何移动一个redis数据库从一个服务器到另一个?
- 如何首次配置postgresql ?