- 1、本文档共43页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
SQL Server 数据库程序设计 授课教师:姜 姗 6.3完整性与约束 数据库中的数据现实世界的反映,数据库的设计必须能够满足现实情况的实现,即满足现实商业规则的要求,这也就是数据完整性的要求。 在数据库管理系统中,约束是保证数据库中的数据完整性的重要方法。 使用表设计器创建FOREIGN KEY约束 打开需要建立外键的表设计器,在需要设置外键的列上单击鼠标右键选择【关系】命令。 打开【外键关系】对话框,单击表和列规范后面的…按钮,设置外键关系。 使用数据库关系图建立外键 使用T-SQL语句创建FOREIGN KEY约束 创建外键约束的语法形式如下:[ CONSTRAINT constraint_name] [ FOREIGN KEY ]REFERENCES referenced_table_name (column_name) [([, …n ]) ] 参数说明如下:referenced_table_name是FOREIGN KEY约束引用的表的名称。 column_name是FOREIGN KEY约束所引用的表中的某列。 3.UNIQUE约束UNIQUE约束用于确保表中某个列或某些列(非主键列)没有相同的列值。与PRIMARY KEY约束类似,UNIQUE约束也强制唯一性,但UNIQUE约束用于非主键的一列或多列组合,而且一个表中可以定义多个UNIQUE约束,另外UNIQUE约束可以用于定义允许空值的列。例如在课程表(course_info)中已经定义“课程号”作为主键,而现在对于“课程名”也不允许出现重复,就可以通过设置“课程名”为UNIQUE约束来确保其唯一性。 使用表设计器创建UNIQUE约束 在表设计器需要加入UNIQUE约束的列上单击鼠标右键选择【索引/键】选项。 使用T-SQL语句创建UNIQUE约束 创建唯一性约束的语法形式如下:[ CONSTRAINT constraint_name] UNIQUE [ CLUSTERED | NONCLUSTERED ]其中,CLUSTERED | NONCLUSTERED表示所创建的UNIQUE约束是聚集索引还是非聚集索引,默认为NONCLUSTERED非聚集索引。 【例8】:将course表中cname列设置成为唯一列。 4.CHECK约束CHECK约束用于限制输入到一列或多列的值的范围,从逻辑表达式判断数据的有效性,也就是一个列的输入内容必须满足CHECK约束的条件,否则,数据无法正常输入,从而强制数据的域完整性。例如在学生成绩表(stu_grade)中的“成绩”来讲,应该保证在0 ~100之间,又如在课程信息表(course_info)中的“学时”来讲,应该保证在0 ~ 80之间,而只用int数据类型是无法实现的,可以通过CHECK约束来完成。 使用表设计器创建CHECK约束 使用T-SQL语句创建CHECK约束 创建检查约束的语法形式如下:[ CONSTRAINT constraint_name] CHECK ( check_expression )其中,check_expression 为约束范围表达式。 5.DEFAULT约束若将表中某列定义了DEFAULT约束后,用户在插入新的数据行时,如果没有为该列指定数据,那么系统将默认值赋给该列,当然该默认值也可以是空值(NULL)。例如,假设学生信息表(stu_info)中的同学绝大多数都来自于“信息学院”,就可以通过设置“系别”字段的DEFALUT约束来实现,简化用户的输入。 使用表设计器创建DEFAULT约束 在表设计器中,选择需要设置DEFAULT值的列,在下面“列属性”的“默认值或绑定”栏中输入默认值,然后单击工具栏中的“保存”按钮,即完成DEFAULT约束的创建。 使用T-SQL语句创建DEFAULT约束 创建默认值约束的语法形式如下:[ CONSTRAINT constraint_name] DEFAULT constraint_expression [with VALUES]其中,constraint _expression 为默认值。 【例9】将表student的电话号码增加默认值‘0371. 启用、禁用约束 启用、禁用约束的语法格式如下: {CHECKINOCHECK}CONSTRAINT{ALL|constraint_name[,…n]} 此语句只能与外键和CHECK约束一起使用,无法禁用DEFAULT、PRIMARY和UNIQUE约束。 【例10】禁用表student中的CK_ssex约束。 ALTER TABLE student NOCHECK CONSTRAINT CK_ssex 【例11】启用表student中的CK_s
您可能关注的文档
- SPSS--数据处理功能——数据整理.ppt
- SPSS--数据探查——数据整理.ppt
- SPSS上机——相关分析与偏相关分析.pptx
- SPSS与统计分析-final-统计的不能和不是.ppt
- SPSS中的方差分析.ppt
- spss图表的创建与编辑.ppt
- SPSS均值比较和T检验.ppt
- SPSS均数比较过程.ppt
- SPSS基本操作和描述性分析.ppt
- SPSS基本统计分析-界面.pptx
- 2023-2024学年广东省深圳市龙岗区高二(上)期末物理试卷(含答案).pdf
- 2023-2024学年贵州省贵阳市普通中学高一(下)期末物理试卷(含答案).pdf
- 21.《大自然的声音》课件(共45张PPT).pptx
- 2023年江西省吉安市吉安县小升初数学试卷(含答案).pdf
- 2024-2025学年广东省清远市九校联考高一(上)期中物理试卷(含答案).pdf
- 广东省珠海市六校联考2024-2025学年高二上学期11月期中考试语文试题.pdf
- 2024-2025学年语文六年级上册第4单元-单元素养测试(含答案).pdf
- 2024-2025学年重庆八中高三(上)月考物理试卷(10月份)(含答案).pdf
- 安徽省安庆市潜山市北片学校联考2024-2025学年七年级上学期期中生物学试题(含答案).pdf
- 贵州省部分校2024-2025学年九年级上学期期中联考数学试题(含答案).pdf
文档评论(0)