- 1、本文档共55页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第五章 数据完整性 ;【本章要点】
1、数据完整性的类型及区别
2、约束的类型及创建和删除
3、默认的创建、绑定和删除
4、规则的创建、绑定和删除 ;5.1 数据完整性概念 ;;5.1.1 域完整性;5.1.2 实体完整性 ;5.1.3 参照完整性 ;数据完整性分析;;5.2 约束(constraints) ;;5.2.1 check 约束 ;方法一、使用SQL Server企业管理器定义、删除check 约束 ;;使用T-SQL语句来创建check 约束;创建客户表的同时定义check 约束要求性别列只能输入“男“ 或者 ”女“
Use 手机
Create table 客户表
( 客户编号 varchar(10) not null,
客户姓名 varchar(10) not null,
客户密码 char(6) not null,
性别 char(2) not null
Constraint ck_性别 check (性别=’男’ or 性别=’女’ ),
证件号 varchar(18 ) not null,
月收入 smallmoney null ) ;;给职工表的学历添加约束;3.使用T-SQL语句删除check 约束(注意:次语句可用于任何一种约束的删除)
语法:
Alter table 表名
Drop constraint 约束名称
(1)删除约束
Alter table 客户表
Drop constraint ck_客户表 ;5.2.2 PRIMARY KEY约束 ;方法一、使用SQL Server企业管理器定义
1、定义PRIMARY KEY约束
【例5】对客户表中的证件号定义PRIMARY KEY约束
;使用T-SQL语句来创建
格式一:创建表的时候创建主键约束
Create table 表名
(……
列名 数据类型 是否为空 constraint 主键约束名 primary key,
……)
格式二:创建好的表添加primary key约束
Alter table 表名
Add
Constraint 主键约束名 primary key(主键列);1、在创建表的同时定义PRIMARY KEY约束
【例6】创建客户表的同时定义列“证件号”为PRIMARY KEY约束
Use 手机
Create table 客户表
( 客户编号 varchar(10) not null,
客户姓名 varchar(10) not null,
客户密码 char(6) not null,
性别 char(2) not null,
证件号 varchar(18 ) not null
Constraint pk_证件号 primary key,
月收入 smallmoney null ) ;创建工资表的同时为职工号创建主键
create table 工资
(职工号char(20) not null constraint cc primary key,
姓名char(20) null,
工资char(20) null);2、删除PRIMARY KEY约束
语法: Drop constraint 主键名称
【例8】删除例5、9中为证件号添加的PRIMARY KEY约束
Use 手机
Alter table 客户表
Drop constraint pk _客户表 ; 练习;5.2.3 FOREIGN KEY约束 ;定义外键约束时应注意以下几点:
1、定义表之间的参照关系时应该先选定主表并定义其主键,再对从表定义外键约束 .
2、定义外键之前必须保证从表与主表相同列的数据满足要求。(相同列从表的数据小于或等于主表数据).
3、一个表最多能够建立253个外键关系。
4、外键约束同时也可以参照自身表中的其他列
5、外键约束,只能参照本身数据库中的某个表,而不能参照其他数据库中的表。跨数据库的参照只能通过触发器来实现。;;使用T-SQL语句来创建、删除FOREIGN KEY约束;Use 手机
Create table 订单表
( 订单编号 varchar(10) not null primary key,
客户编号 varchar(10) not null constraint gg foreign key
References 客户表 (客户编号),
商品编号 varchar(10) not null ,
订购数量 int,
销售额 money,
购物时间 smalldatetime) ;5.2.4 UNIQUE约束 ;
文档评论(0)