位置: 编程技术 - 正文

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

编辑:rootadmin

推荐整理分享详解SQL Server数据库架构和对象、定义数据完整性(sql server数据),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:sql server数据库技术,数据库sql server,sql server数据库基本操作,sql server sql,sql server数据,sql server数据,数据库sql server,sql server数据,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

本节我们继续SQL之旅,本节我们如题来讲讲一些基本知识以及需要注意的地方,若有不妥之处,还望指出,简短的内容,深入的理解。

数据库架构和对象

数据库包含架构,而架构又包含对象,架构可以看做是表、视图、存储过程等对象的容器。架构是一个命名空间,它被用做对象名称的前缀,比如在Cnblogs的架构中有一个名称为Blogs的表,此时我们用架构式限定式名称(即两部分式对象名称)所以Blogs表示为Cnblogs.Blogs。如果我们引用对象时省略了架构名称,SQL Server将会检查对象是否存在用户的默认架构中,如果不是则检查是否存在dbo架构中,当我们创建数据库时,在用户没有显式地指定一个其他架构时,数据库会自动dbo架构作为我们默认的架构。微软也建议在代码中引用对象时始终用【两部分式】对象名称,基于此我们推荐的建议时在引用对象时建议:在代码中始终使用架构限定式的对象名称即两部分式名称。

定义数据完整性

关系模型最大好处则是我们能够自定义数据完整性,同时数据完整性是关系模型不可或缺的一部分,什么是数据完整性,说的通透一点则是对数据进行声明式约束,在SQL Server中声明式约束包括:主键约束、唯一键约束、外键约束、检查约束、默认约束。下面我们一一来介绍这几个约束。

主键约束

下面首先来创建一个表:

主键约束用来强制行的唯一性,上述我们无法表示行的唯一性,现在我们添加约束来强制行的唯一性,用PRIMARY KEY约束如下。

在键文件夹中则生成对列BlogId的约束即升级为主键,如下:

当对主键插入重复数据时会提示插入重复键失败,违反约束。为了强制逻辑主键约束的唯一性,SQL Server会在后台创建一个唯一索引,唯一索引是SQL Server为了强制唯一性而使用的一种物理机制,索引(不一定是唯一索引)是为了加速查询,避免不必要的全表扫描。

唯一约束

唯一约束强制行的唯一性,允许我们在自己的数据库中实现关系模型的备用键概念。它与主键不同,可以在同一个表中定义多个唯一约束同时允许多个NULL标记(类似NULL标记彼此不同),但是SQL Server拒绝重复NULL标记(类似两个NULL标记彼此相等)通过UNIQUE来约束。如下所示对BlogName进行唯一约束。

此时添加唯一约束结果如下

一个个尝试发现居然对字符串和文本类型无法添加唯一约束,涨知识了,不知道为何不能添加唯一约束(补充:在sql R2却可以建立,真纳闷)。

通过上述对主键约束和唯一约束的讲解,我们就搞清楚主键约束和唯一约束了呢?博主看的是SQL Server基础教程,教程就讲到这里结束,至此我是还没弄清楚,主键约束和唯一约束到底应该怎样用以及主键约束和唯一约束有什么区别?

(1)对键添加主键约束,那么能不能在此基础上添加唯一约束呢?

我们在上述已经添加BlogId为主键约束的基础上来添加唯一约束,如下

通过上述我们知道对同一列既可以添加主键约束也可以添加唯一约束。

(2)上述基础教程中也讲到唯一性约束的列可以允许多个NULL标记,真的是这样?我们看看另外一种情况

我们创建如下表

接下来对Id约束为唯一约束。

此时我们对Id添加一个NULL试试看,结果可以插入还是不可以呢?

INSERT INTO TEST VALUES(NULL,'B')

不是唯一约束的列可以为NULL么,难道教程出错了或者sb翻译出错了么,这事我们应该看看定义表时列Id是不能为NULL的,所以到这里我们的疑问算是结束了,唯一约束的列是可以为NULL的。

(3)主键约束和唯一约束的区别?

主键约束:通过对列强制唯一性,此时主键在列上创建一个聚集索引且主键不能为空。

唯一约束:通过对列强制唯一性,此时在列上创建的唯一键为非聚集索引,唯一约束仅仅允许一个NULL值。

二者最大区别在于:主键约束强调的是行的唯一性来标识行,不允许重复,而唯一约束强调的是列的唯一性不允许重复。

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

(4)主键约束和唯一约束都可以建立唯一索引

【1】唯一索引通过主键约束和唯一约束都可以创建。

  如果表中不存在聚集索引的话并且我们没有明确指定一个非聚集索引的话,通过主键约束将自动创建一个唯一聚集索引。

  当创建唯一约束时,默认情况下一个非聚集索引会被创建来强制一个唯一约束,如果在表中聚集索引不存在的话,我们可以指定一个聚集索引。

【2】唯一约束和唯一索引区别

我们接下来创建一个表,如下:

首先我只对Code创建唯一索引

CREATE UNIQUE INDEX uq_ix ON dbo.test(Code)

此时我们再在Code列上添加唯一约束:

此时我们在索引文件夹下可以看到所创建的唯一索引和唯一约束所创建的唯一非聚集索引

看起来二者都是唯一非聚集索引,只是图标不一样而已,二者应该是一样的吧

(5)唯一索引和唯一约束的区别在哪里?唯一约束能替代唯一索引吗?

【1】返回错误码不同

当我们插入数据时,唯一索引返回错误代码为

唯一约束返回的错误代码为

【2】唯一约束不能筛选,而唯一索引能进行筛选,如下

总结:上述只是表示二者在使用上的不同,对于唯一约束和唯一索引并没有什么很大的差异,同时对于唯一约束和唯一索引在查询性能上也没有很大的不同,对于唯一约束我们一直强调的是数据完整性,对列进行唯一约束保证其值不能重复,这同时对于建立索引查询时性能会有显著的提升。

外键约束

外键约束也用来强制数据完整性,外键的目的是限制在外键列中允许的值主要存在于那些被引用列中。下面我们来演示外键约束,我们创建如下雇员表和部门表:

由上我们知道雇员表是依赖于部门表,一个雇员到底是在哪个部门呢?所以此时雇员表中的部门Id应该是部门表中部门Id的外键,接下来我们进行外键约束,如下:

此时执行完你会发现如下错误:

现在我们知道外键可不是随便就能建立的,为什么会出现我们引用部门表并将其雇员表中部门Id作为外键约束的错误呢?通过上述错误我们知道在引用表即部门表中没有其匹配的主键或候选键,这是指的什么,它的意思是引用表中的外键必须是被引用表中的完整主键,而不是作为被引用表的一部分,说的更加明确一点则是被引用表即部门表中的部门Id应该是主键,在这里我们未对部门表中部门Id进行主键约束而导致如上错误。我们添加主键约束即可

此时外键约束才算建立完成。到这里其实还存在一种可能,当我们需要引用的表中已经存在一个主键,而不是由外键引用的列,此时部门表中的Id不是作为主键,而我们雇员表中的部门Id又需要将部门Id作为外键约束,这个时候我们只需要在部门表中部门Id上创建唯一或者唯一约束即可。

或者唯一约束

Check约束

Check约束定义一个谓词,要插入到表中的行或者被修改的行必须满足此要求。

比如在雇员表中再添加一个薪水字段,很显然薪水必须为正值,此时我们则可以像如下进行Check约束

如果试图插入非正值,将会被数据库所拒绝。我们需要注意的是Check约束只是对于结果为false才会拒绝,如果结果为True或者UNKNOWN是会被接受,即当结果为NULL时也会插入或者修改成功。

默认约束

默认约束无非就是当建立表时给定一个默认值,常见的是在表中存在添加数据的日期这一列,此时我们完全给定一个默认值,取当前的日期。默认约束用DEFAULT关键字表示。例如如下:

总结

本节我们详细讲解了主键约束和唯一约束这一块,其余相对比较简单,算是略过,到此结束,下节再会。

标签: sql server数据

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

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

下一篇:详解SQL Server的简单查询语句(sql server功能介绍)

  • 增值税进项税抵扣时间
  • 外地预缴所得税的会计分录
  • 财务报告与财务报表的联系与区别
  • 发票开票地址是注册地址还是经营地址
  • 销售使用过的汽车如何缴纳增值税
  • 税金及附加包括什么
  • 小微企业免征工会经费
  • 购货发票属于外来原始凭证吗为什么
  • 代国外佣金代扣税金账务怎么处理?
  • 以固定资产增资子公司 可以溢价么
  • 充值卡充值发票可以报销吗
  • 劳务发票个人所得税计算器
  • 小规模纳税人增值税怎么算
  • 蔬菜销售收入免增值税吗
  • 个税经营所得预扣预缴
  • 个体户的定额发票怎么领
  • 企业注销增值税进项核销账务处理流程
  • 企业购买商品房限购吗
  • 增值税普通发票几个点
  • 法定代表人的个人债务会执行公司财产么
  • 交强险保单被保险人写谁都行?
  • 残疾人就业保障金是什么意思啊
  • win10回退到以前版本失败
  • 企业收到留抵退税宣传报道
  • php怎么把图片存入mysql
  • 稽查补交的税款怎么处理
  • 苹果mac修改用户名和密码
  • 支付费用没有发票怎么做账务处理
  • tdxcef.exe进程
  • 设备进项抵扣新政策
  • 计提本月银行借款利息是收付实现制还是权责发生制
  • 影视公司纳税标准
  • 持有至到期减值准备是什么科目
  • 资产类备抵科目借方是加还是减
  • 报销加油票怎么开票
  • swift 协议扩展
  • 固定资产和无形资产计提折旧时间
  • php怎么上传图片并保存到数据库
  • 应交税费如何调整
  • 农民专业合作组织
  • 管家婆中已经过账的进货单怎么删除?
  • 转账错误被退款怎么处理
  • vscode主题插件护眼
  • mongodb $sum
  • 什么企业不用交残保金
  • 有下列情形之一的,当事人可以解除
  • 医院怎么开发票?
  • 核定征收的企业所得税怎么算
  • 如何在个人所得税app上修改扣缴义务人
  • 个税里的年金是指
  • 税务会计账务处理一般方法有哪些
  • 出售设备账务处理
  • 库存商品核算
  • 有限合伙企业的特征
  • 年平均资金占用额是动态平均数吗
  • 账户信息变更说明
  • 支付宝如何支付医保费用
  • 收到存款利息收入用什么凭证
  • 私营企业主的现金流特征
  • MySQL数据库同时查询更新同一张表的方法
  • 怎么怎么恢复
  • ubuntu docker教程
  • macbook怎么关闭设置上的1
  • linux中使用grep命令显示包含特殊字符的行
  • windows7显示桌面的操作方法
  • windowsxp复制粘贴不可用?
  • mom.exe是什么程序
  • 附件中的应用程序
  • win10资源管理器启动不了
  • jquery教程chm
  • macos安装过程
  • 简单的小创意
  • 由浅入深易,由深入浅难
  • php删除代码
  • android基础入门教程
  • javascript入门教学
  • java中主要使用unicode编码方式
  • 百望税控盘电子发票发送邮箱
  • 北京亦庄开发区属于哪个区
  • 领完发票后 怎么读取
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设