位置: 编程技术 - 正文

浅述SQL Server的语句类别 数据库范式 系统数据库组成(sql server概述)

编辑:rootadmin

推荐整理分享浅述SQL Server的语句类别 数据库范式 系统数据库组成(sql server概述),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:sql server的使用方法,sql server的功能和特点,sql server的功能和特点,sql server的功能和特点,简述sql server,sqlserver基本介绍,sql server的主要功能和特点,sql server概述,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

终于等到这一天,我要开始重新系统学习数据库了,关于数据库这块,不出意外的话,每天会定时更新一篇且内容不会包含太多,简短的内容,深入的理解。

SQL语句类别

SQL语句包括以下三个类别

(1)数据定义语言(Data Definnition Language)即DDL,我们数据最终从何而来,当然首先必须得建立表,所以它包括CREATE、ALTER、DROP表。

(2)数据操作语言(Data Manipulation Language)即DML,我们对数据需要进行什么操作,当然无非就是增删改查,所以它包括SELECT、INSERT、UPDATE、DELETE,其中还包括TRUNCATE、MERGE。

(3)数据控制语言(Data Control Language)即DCL,我们操作数据库时针对不同的用户会授予不同权限。

数据库范式

范式是什么玩意,它意指规范化规则,通俗易懂一点讲则是定义的规范、规则,需要我们去遵守,那么为何要定这一套规则呢?我们反过来想,肯定是前人遇到过,若不定义这一套规则,则出现这样或那样的问题,为了规避这样问题的出现则出了这一套规则,主要是为了解决如下两点问题。

(1)避免在数据修改过程中出现异常。

(2)保持数据最低限度的冗余。

数据库范式最基础的范式为第一范式(1NF)、第二范式(2NF)、第三范式(3NF),还有更高层次的范式,但太过于复杂我们不做探讨,大部分书籍都这样说,我们就这样去了解。

第一范式(1NF)

定义:关系表中行必须是唯一且属性是原子性的。

太晦涩,太抽象,不太懂,我们一一来分析,我们看看上述定义中重点在于行【唯一】,属性【原子性】。

那么到底什么情况下才算是行唯一呢?

第一:既然是唯一,那么行中某一标识必须是已知而非未知即不能为空

第二:唯一也就是说不能重复诺

第三:怎么保证行唯一呢?通过定义一个唯一键来实现唯一行。

那么到底什么是原子性呢?

第一看到原子这个词语是不是会立马联想到中国独立研制的原子弹爆发,又或者是上化学课遇到的第一个化学式2H2+O2=2H2O,2个氢气即4个氢原子与1个氧气即2个氧原子集合生成1个水分子, 哦,回顾一下,分子是由原子组成,原子由原子核和核外电子组成,原子核又由质子和中子组成,还有什么夸克之类的,无论是程序语言还是数据库中都一直在讲原子性,为什么没有讲质子性和夸克性呢,因为原子已经算是比较小的,所以一直用原子性来强调并划分,为了方便理解,可以这么思考,后面的就不用在叙述,到了这里还没明白么,就相当于原子组成分子,将原子作为最小的粒度即不能再分,那么我们反过来想属性的原子性即属性不可再划分,这又是什么意思,比如在表中有一个地址属性,如果我们存如(湖南省,岳阳市,华容县)这样就违背了第一范式,这个属性还是可以再划分为省、城市、县。

到这里我们可以作出总结第一范式满足的条件:

(1)唯一标识的键

(2)键不能为空

(3)键不能重复

浅述SQL Server的语句类别 数据库范式 系统数据库组成(sql server概述)

(4)属性不可再划分

第二范式(2NF)

定义:在满足第一范式的前提下,每一个非键属性必须满足对整个候选键的完全函数依赖即非键属性不能是对候选键某部分的完全函数依赖。

好了,我们继续入上述解释第一范式来解释第二范式晦涩难懂的定义。我们看下如下表

上述定义候选键都是指的主键。上述给出表中OrderId和ProductId都是作为候选键即主键,但是此时我们可以通过部分候选键(主键)比如OrderId得到OrderDate、CustomerId和CompanyName等列,此时是仅仅是OderId的部分依赖而非对OderId和ProductId二者的完全依赖。此时为了表现出对候选键的完全依赖应该划分成如下两个表。

所以将上述定义通俗讲则是:属性对主键应该属于完全依赖而非部分依赖,否则违反第二范式。

第三范式(3NF)

同样第三范式是在满足第一和第二范式的前提下来看第三范式。

定义:所有非键属性必须依赖于非传递的候选键,也就是非键属性相互之间必须相互独立,进一步讲非键属性之间不能形成依赖关系。

我们看看上述经过修改满足第二范式的两个表,此时订单表中OrderId为主键,客户Id即CustomerId和公司名称即CompanyName对OrderId是完全依赖,我们可以通过订单Id得到客户Id,也可以通过订单Id得到公司名称,同时我们也可以通过客户Id得到客户公司名称,也就是说此时CustomerId和CompanyName是一种传递关系,而非相互之间独立。此时若需要满足第三范式则应该是如下表示:

我们可以看出第三范式着重强调的是非键属性与非键属性之间独立,而第二范式着重强调的是非键属性与候选主键的完全依赖。所以第二范式和第三范式我们统一概括为:非键属性必须是对键的依赖,而非相互之间依赖,并且是对整个键的依赖。

系统数据库组成

当打开数据库中后在数据库下默认会有个系统数据库,里面的内容如下:

master

master数据库存储实例范围的元数据信息、服务器配置、实例中的所有数据库信息和初始化信息。

Resource

Resource数据库是一个隐藏、只读数据库,存储所有系统对象的定义。

model

model数据库是创建新数据库的模板,创建的每个新数据库都是有model的副本初始化创建的。

tempdb

tempdb数据库是SQL Server存储临时数据的地方,如工作表、排序空间、行版本控制信息。同时SQL Server允许我们创建我们自己使用的临时表,并且这些临时表的位置是tempdb,但是我们需要注意的是每当重新启动SQL Server实例时,该数据库将会被破坏掉,并由model副本创建。

msdb

msdb数据库是SQL Server代理的服务存储数据的地方,SQL Server代理负责自动操作,包括作业、计划和警报,同时也负责复制服务等等。

总结

本节我们着重讲解了SQL语句的组成以及数据库的三个范式,对系统数据库的组成进行简短的介绍,属于了解的范畴吧,今天我们先到这里,我们下节再会。

标签: sql server概述

本文链接地址:https://www.jiuchutong.com/biancheng/318993.html 转载请保留说明!

上一篇:如何快速删掉SQL Server登录时登录名下拉列表框中的选项(如何快速删掉通讯录联系人)

下一篇:详解SQL Server数据库架构和对象、定义数据完整性(sql server数据)

  • 城建税及教育费附加怎么计算
  • 车位销售技巧
  • 没有上市的公司怎么看财务报表
  • 做了销售之后的结果
  • 成本费用总额占营业收入比重
  • 已报关的货物可以改单价价吗
  • 认缴注册资本的风险
  • 外商投资企业是民营企业吗
  • 中小企业怎么避税
  • 税局代开专票对方隔月退回重开如何做账务处理呢?
  • 购销合同没有约定期限
  • 发工资多发了可以要回吗
  • 赠品视同销售会计分录要如何编制?
  • 员工拓展培训进度怎么写
  • 外购的半成品属于原材料吗
  • 固定资产本期折旧额与上期不一样
  • 劳务公司差额征税怎么计算
  • 自助开税票流程
  • 增值税和消费税常用的公式
  • 小规模纳税人需要每月清卡吗
  • 空调要买加湿器吗
  • 财务保证金怎么做分录
  • 家电折旧费法律依据
  • 营改增后小规模纳税人如何报税
  • 增值税销项税额抵减账务处理
  • mac电脑新手使用
  • 本月无销售额,但是有进项,需要认证吗
  • cmdkill进程
  • powergenie是什么程序
  • 高新技术企业加计5%
  • 应用程序无法正常启动0xc000007b
  • php header Content-Type类型小结
  • 土地增值税安置房收入的确认原则
  • 未达起征点纳税人房产税土地使用税如何缴纳
  • 向银行贷款资金成本率计算公式是什么
  • 稽查查补税款会计分录
  • php用mysql连接数据库并查询
  • 真实世界人工智能
  • unity loom插件
  • mkv视频制作
  • 微服务docker打包规范
  • 发票作废冲红怎么做账
  • 普通发票不满8项怎么开明细
  • 非企业指的是什么
  • c语言fread函数的用法示例
  • mysql事务引擎
  • 固定资产的财务业绩是什么意思啊
  • 年金现值和终值的关系
  • 上个月没有清卡在其他地区税务
  • 工业生产的含义
  • 收入总额是什么意思
  • 会员退费怎么算
  • 研发支出的费用化支出计入
  • 运输公司内账会计每天需要做什么
  • 管理费用抵消分录
  • 开具红字发票后所冲销的销项税应该怎么处理?
  • 资产负债表日后非调整事项应当在附注中披露
  • 小规模纳税人从三万到十万
  • 代扣代缴增值税申报期限
  • 排序mysql
  • 如何防止sql注入及数据安全问题
  • ubuntu20.04软件安装
  • 重庆四日游最佳攻略超详细
  • win8系统升级到win10东西还在吗
  • win10预览版21277下载
  • window10节电模式怎么关闭
  • 远程桌面的文件怎么无法复制到本地桌面
  • linux安全性从何而来
  • windows8安装步骤
  • 在linux操作系统中把外部设备当作文件统一管理
  • js匿名函数作用域
  • perl 文件
  • Node.js中的什么模块是用于处理文件和目录的
  • linux查看端口占用情况并杀掉进程
  • unity mobile3d
  • javascript基础类型
  • 60后歌手有哪些
  • 企业所得税汇总纳税备案表
  • 国税系统升级后怎么添加办税人
  • 查账征收个人经营所得税怎么申报
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设