SQL Server数据库应用技术实例教程 李东芸 任务四新.ppt
文本预览下载声明
任务四 保证数据的准确性、一致性和完备性 —在SQL Server 2005中实施数据完整性 了解数据完整性的概念 SQL Server 2005中的数据完整性机制 创建、应用约束实施数据完整性,管理约束 使用关系图工具创建数据库关系图实施数据完整性 创建、应用默认值实施数据完整性,管理默认值 创建、应用规则实施数据完整性,管理规则 创建、应用触发器实施数据完整性,管理触发器 4.1 了解数据完整性 任务:建立数据完整性的概念,了解SQL Server 2005中的数据完整性机制。 1.“高职院校教学管理系统”中的域完整性 (1)表student_info中的列zipcode和teacher_info中的列tzipcode拥有自定义数据类型code。 (2)表student_grade中的列grade和credit使用检查约束指定取值范围分别为0=grade=100和0=credit=6。 (3)表student_info和表teacher_info中的列gender指定为bit型,取值只能是1(男)或0(女)。 (4)多个列拥有DEFAULT约束,如列profession的默认值为“副教授”,gender的默认值为1。 2.“高职院校教学管理系统”中的实体完整性 (1)共包含九个表,每个表具有唯一一个主键 (2)表teacher_info的列identity_card指定UNIQUE约束,避免身份证号码重复。 3.“高职院校教学管理系统”中的参照完整性 4.2 应用约束 任务:了解SQL Server 2005中的约束类型及作用。创建、应用NOT NULL、PRIMARY KEY、UNIQUE、CHECK、DEFAULT、FOREIGN KEY约束强制数据完整性,对约束进行简单管理。 约束(CONSTRAINT)是强制数据完整性非常有效的方法,属于声明型数据完整性。 对数据库来说,约束分为列约束和表约束。 列约束作为列定义的一部分只作用于该列。 表约束作为表定义的一部分,作用于表的多列。 SQL Server 2005包含六种基本约束: (1)PRIMARY KEY 约束:实施实体完整性。 (2)UNIQUE 约束:实施实体完整性。 (3)DEFAULT约束:实施域完整性。 (4)CHECK约束:实施域完整性。 (5)NOT NULL约束:实施域完整性。 (6)FOREIGN KEY约束:实施参照完整性。 如下代码中既包含列约束,又有表约束。 CREATE TABLE course_info4 ( course_id char (10) NOT NULL , --列约束,列定义的一部分 course_name nvarchar(40) NOT NULL, --列约束, book_id char(10) NOT NULL, --列约束,列定义的一部分 week_period tinyint NULL DEFAULT ((4)), --列约束,列定义的一部分 total_period tinyint NULL DEFAULT ((60)), --列约束,列定义的一部分 credit tinyin NOT NULL CHECK (0=credit AND credit=6) --列约束,列定义的一部分 CONSTRAINT pk_course_info4 PRIMARY KEY(course_id) , --表约束,表定义的一部分 CONSTRAINT fk_course_info_book_info FOREIGN KEY (book_id) REFERENCES book_info(book_id) --表约束 启动SSMS,打开“对象资源管理器”,依次展开“数据库”→JXGL→“表”节点。 1.创建PRIMARY KEY约束 2.创建NOT NULL约束 3.创建DEFAULT约束 4.创建UNIQUE约束 5.创建CHECK约束 6.创建FOREIGN K
显示全部