SQL 中单引号与双引号的使用要求(严格区分)

SQL中单引号和双引号使用有严格区分:单引号用于包裹字符串、日期等数据值,必须使用且不能混用双引号;


双引号主要用于包裹含特殊字符、空格或保留关键字的对象名(表名、列名、别名),在Oracle中还可保留对象名大小写。


单引号内如需使用单引号需用两个单引号转义。


不同数据库对双引号处理略有差异,建议统一使用单引号处理数据值,仅在必要时使用双引号处理对象名,以保持SQL语句的规范性和可移植性。


SQL中单引号与双引号的使用要求

Oracle / MySQL / SQL Server 等主流数据库中,单引号和双引号有严格区别,不能混用。


一、核心规则

符号 用途 说明
单引号 '' 包裹字符串、日期、字符型数据 必须使用,不能用双引号替代
双引号 "" 包裹对象名(表名、列名、别名) 主要用于区分大小写、特殊字符或关键字

二、单引号的使用(必须掌握)

1. 字符串值必须用单引号

sql

复制代码
-- ✅ 正确
SELECT * FROM EMP WHERE ENAME = 'SMITH';
SELECT * FROM EMP WHERE JOB = 'CLERK';

-- ❌ 错误(双引号包裹字符串)
SELECT * FROM EMP WHERE ENAME = "SMITH";  -- Oracle报错

2. 日期比较时,字符串格式日期用单引号

sql

复制代码
-- ✅ 正确
WHERE TO_CHAR(HIREDATE, 'YYYY') = '1981';
WHERE HIREDATE < TO_DATE('19810501', 'YYYYMMDD');

-- ❌ 错误
WHERE TO_CHAR(HIREDATE, 'YYYY') = 1981;   -- 类型不匹配(虽然可能隐式转换)

3. 单引号内的单引号需要转义(两个单引号表示一个)

sql

复制代码
-- 查询名字中包含单引号的员工,例如 O'Brian
SELECT * FROM EMP WHERE ENAME = 'O''Brian';
--                                ↑↑ 两个单引号表示一个单引号

三、双引号的使用(特定场景)

1. 别名包含空格或特殊字符时

sql

复制代码
-- ✅ 双引号包裹含空格的别名
SELECT ENAME AS "Employee Name" FROM EMP;

-- ✅ 双引号包裹中文别名(某些数据库需要)
SELECT ENAME AS "姓名", SAL AS "薪资" FROM EMP;

-- ❌ 不加双引号会报错
SELECT ENAME AS Employee Name FROM EMP;  -- 空格导致语法错误

2. 对象名区分大小写(Oracle 特殊要求)

Oracle 默认将对象名转为大写,使用双引号可以保留原始大小写:

sql

复制代码
-- 创建时使用双引号保留小写
CREATE TABLE "myTable" (id NUMBER);

-- 查询时必须使用双引号且大小写匹配
SELECT * FROM "myTable";   -- ✅ 正确
SELECT * FROM myTable;     -- ❌ 错误,Oracle 会找 MYTABLE

3. 使用保留关键字作为对象名

sql

复制代码
-- 使用双引号包裹关键字
SELECT * FROM "USER" WHERE "ROWNUM" < 10;

四、对比总结表

场景 正确用法 错误示例
字符串值 'SMITH' "SMITH"
日期字符串 '1981-05-01' "1981-05-01"
普通别名 AS 姓名AS "姓名" 无特殊要求
含空格别名 AS "Employee Name" AS Employee Name
中文别名 AS "姓名"(推荐) AS 姓名(部分数据库可用)
表名/列名 一般不用引号 特殊场景才用双引号

五、你作业中的相关错误

第10题的问题:

sql

复制代码
-- 您的写法(可能报错)
ORDER BY ename asc,年薪 desc;

-- ✅ 正确写法(加双引号)
ORDER BY ename ASC, "年薪" DESC;

-- ✅ 或避免使用中文别名排序
ORDER BY ename ASC, (sal + NVL(comm,0)) * 12 DESC;

六、快速记忆口诀

字符串用单引号,对象名用双引号
单引号里套单引号,两个单引号少不了
双引号别乱用,大小写空格关键字才用到


七、各数据库差异说明

数据库 双引号行为 单引号行为
Oracle 区分大小写对象名 标准用法
MySQL 默认不区分,需配置 标准用法(" 也可用 sql_mode 控制)
SQL Server 区分大小写(取决于排序规则) 标准用法
PostgreSQL 严格区分大小写 标准用法

最佳实践:统一使用单引号包裹字符串和日期,尽量避免使用双引号(除非必要),保持SQL简洁可移植。

相关推荐
号码认证服务3 小时前
如何让经销商接电话时看到“XX集团”?申请号码认证统一上线
服务器·经验分享·sql·华为·智能手机·华为云·云计算
@北海怪兽5 小时前
SQL常见函数整理 _ STRING_AGG()
android·数据库·sql
北秋,5 小时前
Web Security Academy 第四关:SQL 注入查询 MySQL / SQL Server 版本
数据库·sql·mysql
未若君雅裁5 小时前
MySQL慢SQL排查实战-从定位到EXPLAIN优化闭环
sql·mysql
丑八怪大丑8 小时前
JDBC基础篇
java·sql
承渊政道10 小时前
从ROWNUM到LIMIT:KES、Oracle与PostgreSQL的执行顺序差异解析
数据库·数据仓库·sql·mysql·安全·postgresql·oracle
尚雷558010 小时前
Oracle 多租户架构下常用运维SQL
数据库·sql·oracle
StarRocks_labs11 小时前
KaptureCX 大规模实时分析架构演进:基于 RisingWave 与 StarRocks 的最佳实践
starrocks·sql·clickhouse·ai赋能·kapture
Elastic 中国社区官方博客11 小时前
Elasticsearch ES|QL “读取时模式”:你的未映射字段一直都在那里
大数据·数据库·sql·elasticsearch·搜索引擎·全文检索
Elastic 中国社区官方博客11 小时前
Elasticsearch 查询日志:每个查询一行协调器级别日志,适用于 ES|QL、DSL、SQL 和 EQL
大数据·数据库·sql·elasticsearch·搜索引擎·全文检索·可用性测试