创建和管理数据表.ppt

上传人:F****n 文档编号:96078612 上传时间:2019-08-23 格式:PPT 页数:41 大小:1.34MB
返回 下载 相关 举报
创建和管理数据表.ppt_第1页
第1页 / 共41页
创建和管理数据表.ppt_第2页
第2页 / 共41页
创建和管理数据表.ppt_第3页
第3页 / 共41页
创建和管理数据表.ppt_第4页
第4页 / 共41页
创建和管理数据表.ppt_第5页
第5页 / 共41页
点击查看更多>>
资源描述

《创建和管理数据表.ppt》由会员分享,可在线阅读,更多相关《创建和管理数据表.ppt(41页珍藏版)》请在金锄头文库上搜索。

1、第四章 创建和管理数据表,预习检查,至少说出SQL Server中三种数据类型 举例说明在哪些情况下要用到检查约束 什么是标识列,其作用是什么? 什么是数据完整性? 创建数据表的T-SQL语句是什么?,本章目标,掌握SQL Server常用数据类型。 能够使用图形工具SSMS和T-SQL语句创建数据表。 能够为表创建主键、外键、设置默认值、建立检查约束和非空约束、创建标识列等以确保数据完整性。,SQL Server常用数据类型,数据表用于存储各种数据。 不同类型的数据又适合不同的存储方式,从而适合不同的数据类型。 首先应该了解需要存储的数据在SQL Server数据库中的对应哪种数据类型,或者

2、说这些数据适合以何种数据类型存储。,二进制数据类型,文本数据类型,Bit数据类型,数字数据类型,时间和日期数据类型,数据类型示例,身份证号:可能是18位或15位,可以选择 nvarchar(18) 姓名:中国名字大多三个字,且可变长度,可选 择可以选择nvarchar(10) 性别:只有男女,可选择bit或char(1) 家庭地址:可变长度的字符串,nvarchar(200) 电话:可变长度的字符串,nvarchar(20) 生日:可选择日期数据类型,datatime 存款余额:可选择money数据类型 照片:可选择image数据类型,数据完整性的问题大多是由于设计引起的。 数据存放在表中,创

3、建表的时候,就应当保证以后数据输入是正确的错误的数据、不符合要求的数据不允许输入。,数据完整性,数据完整性(Integrity) 是指数据的准确性(Accuracy) 和可靠性(Reliability)。,保证数据的完整性 = 实施完整性约束,输入的类型是否正确? 年龄必须是数字 输入的格式是否正确? 身份证号码必须是18位 是否在允许的范围内? 性别只能是“男”或者“女” 是否存在重复输入? 学员信息输入了两次 是否符合其他特定要求? 学生的出生日期必须小于入学日期 ,完整性问题举例,提供四种类型的约束保证完整性,四种完整性约束,实体完整性,约束方法:唯一约束、主键约束、标识列,实体完整性

4、(Entity Integrity) 指表中数据行的完整性,主要用于保证每条记录非空、唯一且不重复。,域完整性,约束方法:限制数据类型、检查约束、外键约束、默认值、非空约束,学号要求8位字符,域完整性 (Domain Integrity) 又称列完整性,保证列数据具有正确的数据类型、格式和有效的取值范围、精度等。,约束方法:外键约束,参照(引用)完整性,参照完整性 (Referential Integrity) 又称引用完整性,保证主表中的数据与从表中数据的一致性,参照完整性的操作要求,参照完整性禁止以下几种操作: (1) 禁止外键列中插入主键列中没有的值;即外键的取值必须是主表中主键的有效值

5、,或者说向从表中插入数据时只能添加主表中已经存在的关联记录的相关信息。 例如银行开户只能给储户信息表中已经存在的储户开户;学生成绩表中不能添加学生信息表中不存在的学号的成绩信息。 (2) 禁止只修改主表中主键列的值,而不修改从表中相应的外键列的值;即不能更改主表中的值而导致从表中的记录孤立无意义。 例如学生信息表中一个学生学号变了,那么学生成绩表中该学生的学号也必须相应改变。 (3) 禁止先从主表中删除数据行;即主表中删除数据时,必须首先删除从表中的关联记录,否则从表中会遗留大量无意义的记录。,自定义完整性,约束方法:规则、存储过程、触发器,用户自定义完整性 (User-defined Int

6、egrity) 是对列数据的约束,允许用户定义不属于以上三种完整性分类的特定的规则,包括列的值域、列的类型和列的有效规则等约束,这些是由确定关系结构时所定义的字段的属性决定的。,示例:信用不良的客户“马六”不能办理会员证。,创建数据表,通过三大范式规范数据库设计并绘制数据库模型图后,就可以在数据库中创建数据表。 创建表的基本步骤: 第一步,确定表中有哪些列; 第二步,确定每列的数据类型; 第三步,给表添加各种约束; 第四步,创建各表之间的关系。,使用图形化向导创建数据库表,思考:空值NULL 身份证允许为空吗? 姓名允许为空吗? 家庭地址允许为空吗? 电子邮件信息允许为空吗? 性别允许为空吗?

7、,保存并命名数据表,在主键列输入的数值,允许为空吗? 一个表的主键可以有多个列组成吗?,思考-主键,为depositor表创建主键,为depositor表添加默认值,示例:为gender列设置默认值1。,为depositor表建立检查约束,示例:为depositorID建立检查约束,要求该列长度只能是15位或18位。,标识列允许为字符数据类型吗? 如果标识列A的初始值为1,增长量为2,则输入三行数据以后,再删除两行,下次再输入数据行的时候,标识值从多少开始?,思考-标识列,设置标识列,建立表间(主外键)关系,数据库关系图,利用主外键的对应、图形化表示表之间的关系,当主表中没有对应的记录时,不能

8、将记录添加到子表 成绩表中不能出现在学员信息表中不存在的学号 不能更改主表中的值而导致子表中的记录孤立 把学员信息表中的学号改变了,学员成绩表中的学号也应当随之改变 子表存在与主表对应的记录,不能从主表中删除该行 不能把有成绩的学员删除了 删除主表前,先删子表 先删学员成绩表、后删除学员信息表,主外键建立后注意事项,使用T-SQL语句创建数据表,建表的语法,CREATE TABLE 表名 ( 列名1 数据类型 列的特征, 列名2 数据类型 列的特征, . ),列的特征: 包括该列是否为空(NULL)、是否是标识列(identity)、是否有默认值(default)、是否为主键(Primary

9、Key)等,创建表Student,USE StudentInfo -将当前数据库设置为 StudentInfo GO CREATE TABLE Student -创建学生信息表 ( StudentID nvarchar(20) NOT NULL, -学号,非空(必填) password nvarchar(50) NOT NULL, -密码,非空(必填) Name nvarchar(50) NOT NULL, -姓名,非空(必填) gender bit NOT NULL, -性别,非空(必填) GradeId int NOT NULL, -年级号(必填) Phone nvarchar(50) N

10、OT NULL, -电话 birthday datetime NOT NULL, -出生日期(必填) Address nvarchar(255), -地址 Email nvarchar(50), -邮件帐号 stuIDENTITY varchar(18) NOT NULL -身份证号 ) GO,布尔值 TRUE 和 FALSE 可以转换为以下 bit 值:TRUE 转换为 1,FALSE 转换为 0,创建Student表,使用T-SQL语句修改数据表,1、ALTER TABLE 表名 ADD COLUMN 列名 数据类型 列特征 -增加一个新列 2、ALTER TABLE 表名 add CON

11、STRAINT 约束名 DEFAULT 默认值 FOR 列名 -设置默认值 3、ALTER TABLE 表名 RENAME column 列名 TO 新列名 -修改列名 4、ALTER TABLE 表名 RENAME TO 新表名 -修改表名 5、ALTER TABLE 表名 ADD CONSTRAINT 约束名称 约束类型 (列) -添加约束,常用的数据表修改语句:,回顾数据完整性,实体完整性 能够唯一标识表中的每一条记录 实现方式:主键、唯一键、IDENTITY属性 域完整性 表中特定列数据的有效性,确保不会输入无效的值 实现方式:类型、缺省值、约束、空值 引用完整性 维护表间数据的有效性

12、、完整性 实现方式:建立外键联系另一表的主键 自定义完整性 根据业务处理流程定义的特定业务规则 实现方式:存储过程、触发器、规则,回顾SQL Server的约束,使用约束的目的是确保表中数据完整性。 常用的约束类型有哪些? 主键约束(Primary Key Constraint):要求主键列数据唯一,并且不允许为空 唯一约束(Unique Constraint):要求该列数据唯一,允许为空,但只能出现一个空值 检查约束(Check Constraint):某列取值范围限制、格式限制等 默认约束(Default Constraint):某列的默认值 外键约束(Foreign Key Constr

13、aint):用于两表间建立关系,需要指定引用主表的哪列,主键约束与唯一约束的区别: 1.主键约束所在的列不允许有空值,唯一约束所在的列允许空值 2.每个表中可以有一个主键,多个唯一键,使用T-SQL语句添加约束,添加约束的语法,ALTER TABLE 表名 ADD CONSTRAINT 约束名 约束类型 具体的约束说明,约束名的取名规则推荐采用:约束类型_约束列 主键(Primary Key)约束:如 PK_stuNo 唯一(Unique Key)约束:如 UQ_stuID 默认(Default Key)约束:如 DF_stuAddress 检查(Check Key)约束:如 CK_stuBo

14、rnDate 外键(Foreign Key)约束:如 FK_stuNo,为表添加约束,ALTER TABLE Student ADD CONSTRAINT PK_StuID PRIMARY KEY (StudentID) ALTER TABLE Student ADD CONSTRAINT UQ_Identity UNIQUE (stuIdentity) ALTER TABLE Student ADD CONSTRAINT DF_Address DEFAULT (地址不详) FOR Address ALTER TABLE Student ADD CONSTRAINT CK_birthday C

15、HECK(birthday 1980-01-01) ALTER TABLE Student ADD CONSTRAINT FK_Student_Grade FOREIGN KEY(GradeID) REFERENCES Grade(GradeID) ALTER TABLE Subject WITH NOCHECK -检查约束(学时必须大于等于0) ADD CONSTRAINT CK_ClassHour CHECK (ClassHour=0) GO,添加主键约束(StudentID作为主键),添加唯一约束(因为每人的身份证号全国唯一),添加默认约束(如果地址不填,默认为“地址不详”),添加检查check约束,要求出生日期在1980-1-1之后,添加外键约束(主表Grade和从表Student建立关系,关联列为GradeID),WITH NOCHECK对表中已有数据不做约束检查,因此不能保证表中数据的正确性,建议:创建表结构后应立即添加约束,不要马上插入数据,以避免插入的数据不符合约束要求,保证表中数据满足约束限制,删除约束,如果错误地添加了约束,我们还可以删除约束 删除约束的语法,ALTER TABLE 表名 DROP CONSTRAINT 约束名,例如:Score表的结构比较简单,我们只在scoreID列建立主键就可以。现在删除上机练习4-11中的在(学号、科目号)上建

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 办公文档 > PPT模板库 > PPT素材/模板

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号