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简洁可移植。

相关推荐
南极企鹅5 小时前
MySQL间隙锁&临键锁
数据库·sql·mysql
l1t7 小时前
DeepSeek总结的使用 PEG 实现运行时可扩展的 SQL 解析器
数据库·sql
ZC跨境爬虫9 小时前
SQL学习日志 Day_3 :(SELECT查询语句入门)
数据库·sql·学习·oracle
tkevinjd10 小时前
事务、ACID与隔离
java·数据库·sql
wanghowie14 小时前
26.v3 核心升级:语义层 + 指标体系——禁止 LLM 直连 SQL
数据库·sql
yumgpkpm15 小时前
华为HUAWEI昇腾910B下千问Qwen3.6-27B在的推理加速实践
sql·华为·langchain·json·ai编程·ai写作·gpu算力
ZC跨境爬虫16 小时前
SQL学习日志_Day2_深入SQL语法与数据库层级结构
数据库·sql·学习·oracle
码不停蹄的玄黓16 小时前
MySQL唯一索引能否做主键索引
数据库·sql·mysql
小旭952716 小时前
MySQL 主从复制、MyCat 读写分离与分库分表实战
java·数据库·sql·mysql·database
ZC跨境爬虫16 小时前
SQL学习日志 Day_1:初识SQL,开启数据之旅
数据库·sql·学习