SQL标准简介

SQL 的起源

通常认为,SQL 是 Structured Query Language 的缩写,规范的发音是 “ˌɛsˌkjuːˈɛl”。但是它的前身是著名的关系数据库原型系统 System R 所采用的 SEQUEL 语言,这也是为什么有很多人将其读作 “ˈsiːkwəl” 的来源。也有人类比 GNU 这个词的定义(GNU’s Not UNIX),认为 SQL 是 SQL Query Language 的缩写。 作为一种访问关系型数据库的标准语言,SQL 自问世以来得到了广泛的应用,不仅著名的大型商用数据库产品如 Oracle、DB2、Sybase、SQL Server 等支持它,很多开源的数据库产品如 PostgreSQL、MySQL 等也支持它,甚至一些小型的产品如 Access 也支持 SQL。近些年蓬勃发展的 NoSQL 系统最初是宣称不再需要 SQL 的,后来也不得不修正为 Not Only SQL,来拥抱 SQL。

蓝色巨人 IBM 对关系数据库以及 SQL 语言的形成和规范化产生了重大的影响,第一个版本的 SQL 标准 SQL86 就是基于 System R 的手册而来的。可惜的是, IBM 起先并没有什么产品化的想法,倒是 Oracle 富有远见,在 1979 年率先推出了支持 SQL 的商用产品。随着数据库技术和应用的发展,为各种不同的关系数据库系统提供一致的语言成了一种现实需要。

SQL 的标准化

对 SQL 标准影响最大的机构自然是那些著名的数据库产商,而具体的制订者则是一些非营利机构,例如国际标准化组织 ISO、美国国家标准委员会 ANSI 等。世界各国通常会按照 ISO 标准和 ANSI 标准(这两个机构的很多标准是差不多等同的)制定自己的国家标准。中国也是 ISO 标准委员会的成员国,积极参与标准的制定工作,也会经常翻译一些国际标准对应的中文版。标准为了避免采用具体产品的术语,往往会抽象出很多名词,从而增加了阅读和理解的难度,翻译成中文之后更容易增加理解难度。对于数据库系统实现者而言,很多时候还不如直接读英文版本为好。虽然正式的 ISO 标准不总是像 RFC 那样可以从网络上免费获得,标准草案还是比较容易找到的。待批准的标准草案和最终的标准也没有什么实质上的区别,能够满足日常工作的需要。ISO 网站现在也提供了一些标准和技术报告的免费下载1。

SQL 标准的历史

下面是 SQL 标准简要的发展与演化历史:

  • 1986 年,ANSI X3.135-1986,ISO/IEC 9075:1986,SQL-86。这是 ANSI 首次将 SQL 语言标准化的版本。
  • 1989 年,ANSI X3.135-1989,ISO/IEC 9075:1989,SQL-89。增加了完整性约束。
  • 1992 年,ANSI X3.135-1992,ISO/IEC 9075:1992,SQL-92(SQL2)。最重要的一个版本。 引入了标准的分级概念。
  • 1999 年,ISO/IEC 9075:1999,SQL:1999(SQL3)。变动最大的一个版本。改变了标准符合程度的定义;增加了面向对象特性、正则表达式、存储过程、Java 等支持。
  • 2003 年,ISO/IEC 9075:2003,SQL:2003。引入了 XML、Window 函数等。
  • 2008 年,ISO/IEC 9075:2008,SQL:2008。引入了 TRUNCATE 等。
  • 2011 年,ISO/IEC 9075:2011,SQL:2011。引入了时序数据等。
  • 2016 年,ISO/IEC 9075:2016,SQL:2016。引入了 JSON 等。
    细心的读者能发现,从 SQL:1999 开始,标准简称中的短横线(-)被换成了冒号(:),而且标准制定的年份也改用四位数字了。前一个修改的原因是 ISO 标准习惯上采用冒号,ANSI 标准则一直采用短横线。后一个修改的原因是标准的命名也遇到了 2000 年问题。

SQL86 大概只有几十页,SQL92 正文大约有 500 页,而 SQL99 则超过了 1000 页。可以看出,从 SQL99 开始,SQL 标准的个头就非常庞大了,内容包罗万象,可以说已经没有人能够掌握标准的所有内容了。以 SQL:2003 为例,它包括以下 9 个部分(中间编号空缺是曾经被占用,之后被废弃的标准造成的):

  • ISO/IEC 9075-1: Framework (SQL/Framework)
  • ISO/IEC 9075-2: Foundation (SQL/Foundation)
  • ISO/IEC 9075-3: Call Level Interface (SQL/CLI)
  • ISO/IEC 9075-4: Persistent Stored Modules (SQL/PSM)
  • ISO/IEC 9075-9: Management of External Data (SQL/MED)
  • ISO/IEC 9075-10: Object Language Bindings (SQL/OLB)
  • ISO/IEC 9075-11: Information and Definition Schemas (SQL/Schemata)
  • ISO/IEC 9075-13: SQL Routines and Types Using the Java Programming Language (SQL/JRT)
  • ISO/IEC 9075-14: XML-Related Specifications (SQL/XML)

学习 SQL 标准

负责具体制定工作的是 ISO 和 IEC 联合成立的一个技术委员会 JTC1/SC32。正因为关系数据库市场非常成熟,竞争不够激烈,标准本身变得过于庞大等原因,SQL3 制定的周期很长,制定期间也存在很多争议。例如文章 Is SQL a Real Standard Anymore? 就对 SQL 标准化进程提出了置疑。WISCorp 2 网站曾经收集了很多相关的文档,JCC3 网站则提供了比较新的更新。

如果要了解标准的内容,比较推荐的方法是泛读 SQL92(因为它涉及了 SQL 最基础和最核心的一些内容),然后增量式的阅读其他标准。标准在每次更新的时候,委员会的成员们都为大家提供比较好的介绍文档。例如,针对 SQL:2011,SIGMOD Record 上就有很不错的介绍4。针对 SQL:2016,这是一个很好的更新5,这6也是一个很好的补充。

大约从 2011 年开始,标准委员会还提供了 SQL Technical Reports,虽然它们不是正式标准的一部分,但却非常有助于理解标准。ISO 的这个网页1提供了技术报告的免费下载,注意它们的编号是 19075,而且标题中带 TR 这个缩写词。

SQL 标准的符合性

提及标准,大家容易想到的一个问题就是产品对标准的遵循程度,也就是标准的符合性到底如何,因为它会影响代码在不同系统之间迁移的难度。很遗憾的是,SQL 标准因为定义过于宽泛等技术和非技术原因,不同产品对标准的符合程度存在很大的差异。大到功能特性,小到语法语义的细节,在不同产品之间都存在很多差异,造成实际的应用迁移远比 C/C++ 程序的迁移要复杂很多。因此,尽管很多产品都号称自己符合 SQL 标准,并不意味着应用可以容易的在它们之间切换。除了 Oracle、DB2 等经典的商业产品,以及 PostgreSQL、MySQL 等开源产品总体上对 SQL 标准的符合程度较高以外,很多产品提到的 SQL 标准,涉及的内容其实是 SQL92 里头最基本或最核心的一部分(属于入门级的范畴。SQL92 本身是分级的,包括入门级、过渡级、中间级和完全级)。

为了验证具体的产品对标准的遵从程度,NIST 还曾经专门发起了一个项目,来做标准符合程度的测试集合7。不过,SQL 标准包含的内容实在太多了,而且有很多特性对新的 SQL 产品而言也越来越不重要了。从 SQL99 之后,标准中符合程度的定义就不再分级,而是改成了核心兼容性和特性兼容性;也没有机构来推出权威的 SQL 标准符合程度的测试认证了。开源的 MySQL 曾经在 6.0 的开发过程中试图大幅度改善对 SQL 标准的符合程度,不过后来似乎不了了之了。国产数据库作为数据库领域的后来者,曾经对标准的符合程度非常重视,还组织了专门的机构来做产品的标准符合性测试。在数据库百科全书8中也有很多有关标准的章节。

参考:
1 http://standards.iso.org/ittf/PubliclyAvailableStandards/index.html
2 https://www.wiscorp.com/free_downloads.html
3 http://www.jcc.com/resources/sql-standards
4 http://www.sigmod.org/publications/sigmod-record/1203/pdfs/10.industry.zemke.pdf
5 https://s3.amazonaws.com/artifacts.opencypher.org/website/materials/SQLStandards_2017-10-20.pdf
6 https://modern-sql.com/blog/2017-06/whats-new-in-sql-2016
7 http://itl.nist.gov/div897/ctg/sql_form.htm
8 http://mall.cnki.net/reference/detail_R201109078.html

你可能感兴趣的:(数据库,sql)