iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >SQL语言概况(4.1)
  • 469
分享到

SQL语言概况(4.1)

SQL语言概况(4.1) 2017-08-18 00:08:29 469人浏览 无得
摘要

sql语言概况(4.1) 目录SQL语言概况(4.1)4.1 SQL语言概况4.1.1 历史及标准简介4.1.2 SQL语言定义及特点4.1.3 使用说明 参考资料: 数据库原理及设计(第3版) 配套数据库为:microsof

SQL语言概况(4.1)

sql语言概况(4.1)

目录

  • SQL语言概况(4.1)
    • 4.1 SQL语言概况
      • 4.1.1 历史及标准简介
      • 4.1.2 SQL语言定义及特点
      • 4.1.3 使用说明

参考资料:

数据库原理及设计(第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完成数据操纵

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

您可能感兴趣的文档:

--结束END--

本文标题: SQL语言概况(4.1)

本文链接: https://www.lsjlt.com/news/5696.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Go语言在商业界的应用概况
    Go语言是一种由Google开发的开源编程语言,它的设计初衷是为了提升软件开发的效率和简化大型软件系统的构建。自Go语言于2007年发布以来,其在商业界的应用逐渐增加。本文将探讨Go语...
    99+
    2024-03-04
    go语言商业应用 go语言商用 商用go语言 go语言
  • Go语言中SQL的基本概念及用法解析
    Go语言中SQL的基本概念及用法解析 SQL(Structured Query Language)是一种专门用来管理和操作关系数据库的语言。在Go语言中,我们通常使用SQL来执行数据库...
    99+
    2024-04-02
  • 【Java入门】Java的语言概述
    前言 📕作者简介:热爱跑步的恒川,致力于C/C++、Java、Python等多编程语言,热爱跑步,喜爱音乐的一位博主。 📗本文收录于Java入门篇系列,该专栏主要...
    99+
    2023-09-04
    java jvm 搜索引擎 开发语言 经验分享
  • sql语言有哪些
    这篇文章给大家分享的是有关sql语言有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。sql语言包含:数据查询语言,数据操作语言,事务处理语言,数据控制语言,数据定义语言以及指...
    99+
    2024-04-02
  • css语言的概念是什么
    这篇文章主要讲解了“css语言的概念是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“css语言的概念是什么”吧!css语言是一种用来表现HTML或XML等文件样式的计算机语言;其英文全称...
    99+
    2023-07-05
  • Go语言基础概念解析
    go 语言是一门高性能、并发编程语言,其基础概念包括:基本类型(整数、浮点数、布尔值、字符串、字符);通过 var 关键字声明变量,并支持类型推断;使用 const 关键字声明常量;提供...
    99+
    2024-04-08
    go语言 基础概念
  • go语言的概念是什么
    本文小编为大家详细介绍“go语言的概念是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“go语言的概念是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。go语言是一种计算机编程语言,又称Golang,是Go...
    99+
    2023-07-05
  • Go语言GOPATH的概念是什么
    这篇“Go语言GOPATH的概念是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Go语言GOPATH的概念是什么”文章吧...
    99+
    2023-07-05
  • SQL语句中怎么查询Index使用状况
    这篇文章将为大家详细讲解有关SQL语句中怎么查询Index使用状况,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。SELECT  ...
    99+
    2024-04-02
  • javascript是不是sql语言
    本篇内容主要讲解“javascript是不是sql语言”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“javascript是不是sql语言”吧! ...
    99+
    2024-04-02
  • Python面向对象语言的概念
    这篇文章主要讲解了“Python面向对象语言的概念”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python面向对象语言的概念”吧!在我们的程序中,我们都是根据操作数据的函数或语句块来设计程...
    99+
    2023-06-17
  • Go语言中引用类型的概述
    Go语言中引用类型的概述 Go语言是一种由谷歌开发的开源编程语言,其设计目标之一是简洁、高效且易于使用。在Go语言中,引用类型是一种特殊的数据类型,它们在内存中存储的是数据的引用而不是...
    99+
    2024-02-22
    go语言 概述 引用类型 string类 键值对
  • c语言中cls的概念是什么
    在C语言中,"cls"是"clear screen"的缩写,用于清空控制台屏幕上的所有内容。它通常用于在控制台应用程序中清除之前输出...
    99+
    2023-09-29
    c语言
  • php语言里有指针的概念吗
    php不能直接操纵内存,所以php中没有指针。在c语言中主要用的是指针。C语言中可以用一个变量来存放指针,这种变量被叫做指针变量。某份数据的地址就是指针变量的值,这份数据既可以是数组、字符串和函数,也可以是另一个普通变量或指针变量。...
    99+
    2024-04-02
  • Go语言函数和指针的概念
    本篇内容主要讲解“Go语言函数和指针的概念”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Go语言函数和指针的概念”吧!函数函数就是一段基本的代码块,一般用来对需要重复执行的代码进行复用。在 go...
    99+
    2023-06-15
  • 了解Go语言中数组的概念
    数组概述 数组是Go语言中一种基本的数据类型,用于存储一组具有相同类型的数据元素。数组中的每个元素都有一个唯一的索引,可以通过索引来访问该元素。数组的长度是固定的,一旦创建就不能改变。 创建数组 可以使用以下...
    99+
    2024-01-31
    go数组理解 go数组功能 go数组特点 go语言
  • c语言指针的概念是什么
    C语言中的指针是一个变量,用于存储另一个变量的地址。简单来说,指针就是指向内存中某个位置的变量。指针的概念可以帮助我们实现一些高级的...
    99+
    2023-09-16
    c语言
  • sql语言有什么功能
    小编给大家分享一下sql语言有什么功能,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!sql语言具有的功能SQL具有数据定义、数据...
    99+
    2024-04-02
  • sql语言是什么意思
    这篇文章主要介绍了sql语言是什么意思,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。sql语言通常称为结构化查询语言,是一种特殊目的的编程语言,...
    99+
    2024-04-02
  • sql指的是什么语言
    这篇文章将为大家详细讲解有关sql指的是什么语言,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。  结构化查询语言(Structured Query Language)简称...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作