news 2026/4/24 2:59:21

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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简洁可移植。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/24 2:59:20

nli-MiniLM2-L6-H768惊艳效果:小模型在中文法律文本NLI任务上超越BERT-base

nli-MiniLM2-L6-H768惊艳效果&#xff1a;小模型在中文法律文本NLI任务上超越BERT-base 1. 小模型的大能量 在自然语言处理领域&#xff0c;模型大小往往与性能成正比。但nli-MiniLM2-L6-H768打破了这一常规认知&#xff0c;这个仅有630MB的小型模型在中文法律文本的自然语言…

作者头像 李华
网站建设 2026/4/24 2:57:21

Bili2text:3分钟将B站视频转为文字稿的高效工具

Bili2text&#xff1a;3分钟将B站视频转为文字稿的高效工具 【免费下载链接】bili2text Bilibili视频转文字&#xff0c;一步到位&#xff0c;输入链接即可使用 项目地址: https://gitcode.com/gh_mirrors/bi/bili2text 还在为整理B站视频内容而烦恼吗&#xff1f;面对长…

作者头像 李华
网站建设 2026/4/24 2:46:18

zarrow:Zig 生态最完整的 Apache Arrow 实现,为什么值得关注?

在数据基础设施里&#xff0c;Apache Arrow 已经是事实标准。 但在 Zig 生态中&#xff0c;长期缺少一个“够全、够稳、够互通”的 Arrow 实现。 GitHub https://github.com/tylitianrui/zarrow zarrow 的目标非常明确&#xff1a; 不是做薄封装&#xff0c;而是在 Zig 中原…

作者头像 李华
网站建设 2026/4/24 2:40:17

编码基础:ASCII、Unicode、UTF-8 区别与原理

文章目录前言一、编码的本质&#xff1a;计算机怎么认识文字&#xff1f;二、入门基础&#xff1a;ASCII 编码完整详解2.1 ASCII的诞生背景2.2 ASCII底层编码规则2.3 ASCII无法规避的致命缺陷三、全球统一标准&#xff1a;Unicode 核心原理3.1 Unicode诞生的核心目的3.2 关键概…

作者头像 李华