SQL语言概况(4.1)「建议收藏」

SQL语言概况(4.1)「建议收藏」SQL语言概况(4.1) [toc] 参考资料: 数据库原理及设计(第3版) 配套数据库为:microsoft sql server 参照ANSI SQL 92标准 4.1 SQL语言概况 4.1.1

SQL语言概况(4.1)

SQL语言概况(4.1)

参考资料:

数据库原理及设计(第3版)

配套数据库为:microsoft sql server

参照ANSI SQL-92标准

4.1 SQL语言概况

4.1.1 历史及标准简介

一切都源于关系型数据库之父——Edgar Frank Codd 于1970年6月首次提出了关系数据模型。

之后嘛,肯定是经历了以下这个过程:

  • 各学校、公司开始理论研究,看看这个玩意儿能不能给带来利益?!

  • 诶?!好像可以带来利益诶……那我们开发成产品商化吧,再配套一个使用工具(语言)!

  • 权威机构:麻了?!怎么发展的这么蓬勃(五花八门)?!不得行,是时候我出场统一一下标准了!

  • 基于标准开发,再来点扩展,投放市场使用……

    其它公司:诶?!好玩意儿……可是我们的开发应用要界面啊,能不能把这个嵌入到其他语言中使用?!

  • ……

至此,我们来梳理一下真正的历史过程

  • 1974年BoyceChamberlin提出SQL

  • 20世纪70年代中期,IBM公司在研制System R 的过程中,开发了世界上最早的SQL语言

  • 1979年,Oracle公司最先提出了商用的SQL语言

  • SQL标准变迁史

    • 1986年10月,ANSI制订,SQL-86
    • 1989年,ANSI改进,SQL-89
    • 1992年,ANSI与ISO合作改动完善,SQL-92
    • 1999年,增加面向对象特征扩展,提出SQL:1999
    • 2003年,SQL:2003
    • ……

    可以说,命名就很有意思了,就是年份结尾嘛,但是1999年开始变成四位数字,具体原因我也是百度了一篇博客,放出来《SQL标准简介

    https://blog.csdn.net/lengye7/article/details/80606489

    还有一点,非正式的一些称呼

    • 第一代SQL语言,SQL1,SQL-86 & SQL-89
    • 第二代SQL语言,SQL2,SQL-92
    • 第三代SQL语言,SQL3,SQL:1999

其中,针对于SQL-92来说,绝大多数RDBMS产品不是完全支持的,那差异一般都会体现在SQL命令的语法上面。

针对这个不完全支持,我们可以从两个方向上来看

  • SQL-92中的某些功能,在实际RDBMS中可能没有得到支持
  • 实际RDBMS也有可能出现该标准中没有的功能和特性

那么根据支持SQL-92的程度,我们可以分为三种:

  • 入门(entry)级:其功能特性接近SQL-89
  • 中间(intermediate)级:包含SQL-92近一半的新特点
  • 完全(full)版:完全支持

因此,所给的建议是:

  • 使用具体的RDBMS时,查阅产品的技术资料
  • 增强SQL代码的移植性,最好采用在SQL标准中也推荐的功能

4.1.2 SQL语言定义及特点

什么是SQL语言

  • 是最流行的一种数据库语言
  • 结构化查询语言(structured query language
  • 是RDBMS支持的数据库语言

很多人会跟我有一样的疑问,为啥叫查询语言???

  • 首先不要被这个名字误导了,并不是它只支持查询,它的功能还有很多,,比如数据模式定义、数据的“增、删、改”以及安全和事务控制功能。

    所以说……一个好的名字还是很重要的……

  • 具体原因:从操纵数据的角度来看,查询是最重要也是用的最多的操作(想想你们自己管理开发的时候,是不是动不动就要查询这个查询那个?!)

接下来,我们看看这个SQL语言有哪些功能特点呢

  1. 功能一体化。

    说的有点玄乎,实际上就是,它作为数据库语言的一种,也是遵循数据库语言的划分,由3个子语言构成:

    • DDL(data definition language)
    • DML(data manipulation language)
    • DCL(data control language)

    各个自语言又有很多自己的功能……

  2. 语言非过程化。

    之前我们说过,它的名字中有结构化,那什么是结构化,什么是过程化呢?

    • 结构化是相对于过程化来说的
    • 过程化的语言:需要用户在程序设计中指明程序“做什么”,还需要程序员按照一定的算法编写出“怎么做”的程序来。
    • 结构化的预言(以RDBMS为例):用户只需要定义“做什么”,RDBMS系统内部会解决“怎么做”。
  3. 交互式与嵌入式使用。

    • 交互式(interactive):用户直接在RDBMS控制台上使用SQL语言中的SQL命令直接交互。
    • 嵌入式(embedded):在过程化语言(宿主host语言)中使用。
  4. 标准化与易移植性。

    之前,我们也说过,各个具体的RDBMS产品中支持的SQL语言情况是有所差异的,但是大多都能支持标准的大部分,因此,移植起来会相对容易。

4.1.3 使用说明

利用SQL语言,可以完成关系模型的具体化,那我们之前知道,任何模型都包括3方面的内容:

  • 数据结构
  • 完整性约束
  • 数据操纵

那么如何将这三部分具体化呢?

这由SQL语言中的两个子语言承担:

  • DDL完成数据结构和完整性约束
  • DML完成数据操纵

之后,我将会分块对这两个子语言进行学习……

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/8819.html

(0)
上一篇 2023-02-21
下一篇 2023-02-21

相关推荐

  • SQLServer 把某日期更新到某天[亲测有效]

    SQLServer 把某日期更新到某天[亲测有效]例: update cyj_cx_dwjl set xrsj=DATEADD(day, DATEDIFF(day, xrsj, GETDATE()), XRSJ) where CONVERT(VARC

    2023-02-16
    147
  • Cassandra 简介「终于解决」

    Cassandra 简介「终于解决」Cassandra是云原生和微服务化场景中最好的NoSQL数据库。我信了~ 1. Cassandra是什么 高可用性和可扩展的分布式数据库 Apache Cassandra™是一个开源分布式数据,可提

    2023-02-26
    158
  • SQL SERVER 比较两个数据库的差异性「建议收藏」

    SQL SERVER 比较两个数据库的差异性「建议收藏」有时候部署服务器正式版与测试版数据库的时候 总会有忘记某些字段同步更新的问题 不管是字段类型 或是字段名称. 然后等待着的就是一堆的错误日志. 所以一直想找一款可以查找数据库差异性的脚本或软件 运行以

    2023-05-19
    146
  • infinispan~介绍

    infinispan~介绍国内的infinispan的文章不多,所以基本都是从google和官方api上找的资料,对一些问题的调研确实花了一些经历,但最终还是解决了问题,心情也是更加愉悦! 介绍 infinispan是分布式的

    2023-04-29
    141
  • Python编程课程:提升您的编程技能

    Python编程课程:提升您的编程技能Python是一种流行的开源编程语言,它可以轻松解决各种应用场景,例如自动化、数据处理、机器学习和Web开发等。如果您想要学习Python,或者想要提高您的Python编程技能,那么Python编程课程可能是一个不错的选择。在这些课程中,您将学习基本的Python语法、核心概念和高级技术。现在就来了解一下Python编程课程吧!

    2023-12-19
    120
  • python中验证ip正则(正则验证ip地址)

    python中验证ip正则(正则验证ip地址)首先给出一个c函数的原型:int sscanf(const char *buffer,const char *format,[argument ]…)它的返回值是参数的数据,也就是argument的个数,buffer:存储的数据,format:格式控制字符串,argument:选择性设定字符串。这个程序从标准流读取数据,可以进行无限制的输入。下面贴出代码,然后引出另外一个问题,将字符串ip转换成整形ip地址。[cpp]

    2023-11-19
    139
  • 数据库视图显示不了数据怎么办_数据库安装过程出现问题怎么解决

    数据库视图显示不了数据怎么办_数据库安装过程出现问题怎么解决在数据可视化制作的过程中,数据库结构总是在不断的调整和变化中。为了给程序开发者更好的操作体验,简化操作流程,需要在程序测试完毕打包版本的时候,对数据库进行格式操作,以便完成初始化的自动安装。现就如何…

    2023-03-25
    145
  • MySQL 50题练习

    MySQL 50题练习 表名和字段 –1.学生表 Student(s_id,s_name,s_birth,s_sex) –学生编号,学生姓名, 出生年月,学生性别 –2.课程表 Course(c_id,c_name…

    2023-02-21
    128

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注