实验6数据完整性.docx

上传人:b****4 文档编号:3856417 上传时间:2023-05-06 格式:DOCX 页数:16 大小:503.60KB
下载 相关 举报
实验6数据完整性.docx_第1页
第1页 / 共16页
实验6数据完整性.docx_第2页
第2页 / 共16页
实验6数据完整性.docx_第3页
第3页 / 共16页
实验6数据完整性.docx_第4页
第4页 / 共16页
实验6数据完整性.docx_第5页
第5页 / 共16页
实验6数据完整性.docx_第6页
第6页 / 共16页
实验6数据完整性.docx_第7页
第7页 / 共16页
实验6数据完整性.docx_第8页
第8页 / 共16页
实验6数据完整性.docx_第9页
第9页 / 共16页
实验6数据完整性.docx_第10页
第10页 / 共16页
实验6数据完整性.docx_第11页
第11页 / 共16页
实验6数据完整性.docx_第12页
第12页 / 共16页
实验6数据完整性.docx_第13页
第13页 / 共16页
实验6数据完整性.docx_第14页
第14页 / 共16页
实验6数据完整性.docx_第15页
第15页 / 共16页
实验6数据完整性.docx_第16页
第16页 / 共16页
亲,该文档总共16页,全部预览完了,如果喜欢就下载吧!
下载资源
资源描述

实验6数据完整性.docx

《实验6数据完整性.docx》由会员分享,可在线阅读,更多相关《实验6数据完整性.docx(16页珍藏版)》请在冰点文库上搜索。

实验6数据完整性.docx

实验6数据完整性

实验6--数据完整性

一、实验目的

1.掌握Transact-SQL语句(CREATERULE、DROPRULE)创建和删除规则的方法。

2.掌握系统存储过程sp_bindrule、sp_unbindrule绑定和解除绑定规则的操作方法,以及sp_help、sp_helptext查询规则信息、sp_rename更名规则的方法。

3.掌握Transact-SQL语句(CREATEDEFAULT、DROPDEFAULT)创建和删除默认对象的方法。

4.掌握系统存储过程sp_bindefault、sp_unbindefault绑定和解除绑定默认对象的操作方法,以及sp_helptext查询规则信息。

5.掌握SQLServer管理平台和Transact-SQL语句(CREATETABLE、ALTERTABLE)定义和删除约束的方法,并了解约束的类型。

2、实验内容及步骤

(1)为studentsdb数据库创建一个规则,限制所输入的数据为7位0~9的数字。

复制student_info表命名为stu_phone,在stu_phone表中插入一列,列名为“电话号码”。

完成以下代码实现该操作。

SELECT*INTOstu_phoneFROMstudent_info

ALTERTABLEstu_phoneADDCHAR(7)NULL

stu_phone表结构如图1-10所示。

图1-10stu_phone表结构

创建一个规则phone_rule,限制所输入的数据为7位0~9的数字。

实现该规则的代码为

CREATEphone_rule

AS

@phoneLIKE'[0-9][0-9][0-9][0-9][0-9][0-9][0-9]'

使用系统存储过程sp_bindrule将phone_rule规则绑定到stu_phone表的“电话号码”列上。

实现该操作的代码为

sp_bindrule,'stu_phone.电话号码'

输入以下代码,进行一次插入操作:

INSERTINTOstu_phone(学号,姓名,电话号码)VALUES('0009','王国强','1234yyy')

产生以下出错信息:

消息513,级别16,状态0,第1行

列的插入或更新与先前的CREATERULE语句所指定的规则发生冲突。

该语句已终止。

冲突发生于

数据库'studentsdb',表'dbo.stu_phone',列'电话号码'。

语句已终止。

试分析:

为什么会产生该出错信息?

如果要实现插入操作,应修改INSERTINTO语句中的哪个值?

phone_rule规则能否对其他操作(如DELETE)进行规则检查?

(2)创建一个规则stusex_rule,将其绑定到stu_phone表的“性别”列上,保证输入的性别值只能是“男”或“女”。

(3)使用系统存储过程sp_help查询stusex_rule规则列表,使用sp_helptext查询stusex_rule规则的文本,使用sp_rename将stusex_rule规则更名为stu_s_rule。

(4)删除stu_s_rule规则。

 

stu_s_rule(stusex_rule更名后规则名)是否仍然绑定在stu_phone表的“性别”列上?

应如何操作才能删除它?

(5)在studentdb数据库中,建立日期、货币和字符等数据类型的默认对象。

在查询设计器中,完成以下代码,创建默认对象df_date、df_char、df_money。

--创建日期型默认对象df_date

CREATEdf_date

AS'2009-4-12'

GO

--创建字符型默认对象df_char

CREATEDEFAULTdf_char

'unknown'

GO

--创建货币型默认对象df_money

CREATEDEFAULT

AS$100

GO

输入以下代码,在studentsdb数据库中创建stu_fee数据表。

CREATETABLEstu_fee

(学号char(10)NOTNULL,

姓名char(8)NOTNULL,

学费money,

交费日期datetime,

电话号码char(7))

表stu_fee的数据结构如图1-11所示。

图1-11stu_fee的数据结构

使用系统存储过程sp_bindefault将默认对象df_money、df_date、df_char分别绑定在stu_fee表的“学费”、“交费日期”、“电话号码”列上。

df_money,'stu_fee.学费'

GO

sp_bindefault,'stu_fee.交费日期'

GO

sp_bindefaultdf_char,'stu_fee.电话号码'

GO

输入以下代码,在stu_fee表进行插入操作:

INSERTINTOstu_fee(学号,姓名)VALUES('0001','刘卫平')

INSERTINTOstu_fee(学号,姓名,学费)VALUES('0001','张卫民',$120)

INSERTINTOstu_fee(学号,姓名,学费,交费日期)

VALUES('0001','马东',$110,'2006-5-12')

分析stu_fee表中插入记录的各列的值是什么?

完成以下代码,解除默认对象df_char的绑定,并删除之。

'stu_fee.电话号码'

DEFAULTdf_char

按同样的方式,删除默认对象df_date、df_money。

(6)为student_info表添加一列,命名为“院系”,创建一个默认对象stu_d_df,将其绑定到student_info表的“院系”列上,使其默认值为“信息院”,对student_info表进行插入操作,操作完成后,删除该默认对象。

(7)在studentsdb数据库中用CREATETABLE语句创建表stu_con,并同时创建约束。

创建表的同时创建约束。

表结构如图1-12所示。

图1-12要创建的表的结构

约束要求如下:

将学号设置为主键(PRIMARYKEY),主键名为pk_sid。

为姓名添加唯一约束(UNIQUE),约束名为uk_name。

为性别添加默认约束(DEFAULT),默认名称为df_sex,其值为“男”。

为出生日期添加属性值约束(CHECK),约束名为ck_bday,其检查条件为:

出生日期>'1988-1-1'。

在stu_con表中插入如表1-1所示的数据记录。

表1-1在stu_con表中插入的数据

学号

姓名

性别

出生日期

家庭住址

0009

张小东

1989-4-6

0010

李梅

1983-8-5

0011

王强

1988-9-10

0012

王强

1989-6-3

分析各约束在插入记录时所起的作用,查看插入记录后表中数据与所插入的数据是否一致?

使用ALTERTABLE语句的DROPCONSTRAINT参数项在查询设计器中删除为stu_con表所建的约束。

(8)用SQLServer管理平台完成实验内容7的所有设置。

(9)在查询设计器中,为studentsdb数据库的grade表添加外键约束(FOREIGNKEY),要求将“学号”设置为外键,参照表为student_info,外键名称为fk_sid。

使用系统存储过程sp_help查看grade表的外键信息。

在grade表中插入一条记录,学号为0100,课程编号为0001,分数为78。

观察SQLServer会做何处理,为什么?

如何解决所产生的问题?

使用查询设计器删除grade表的外键fk_sid。

三、实验结果

1.为studentsdb数据库创建一个规则,限制所输入的数据为7位0~9的数字。

(1)复制学生表命名为stu_phone,在stu_phone表中插入一列,列名为“电话号码”。

完成以下代码实现该操作。

SELECT*INTOstu_phoneFROM学生表

ALTERTABLEstu_phoneADD电话号码CHAR(7)NULL

stu_phone表结构如图1-10所示。

图1-10stu_phone表结构

 

(2)创建一个规则phone_rule,限制所输入的数据为7位0~9的数字

createrulephone_rule

as@电话号码like'[0-9][0-9][0-9][0-9][0-9][0-9][0-9]'

(3)使用系统存储过程sp_bindrule将phone_rule规则绑定到stu_phone表的“电话号码”列上。

sp_bindrulephone_rule,'stu_phone.电话号码

'

(4)输入以下代码,进行一次插入操作:

INSERTINTOstu_phone(学号,姓名,电话号码)VALUES('0009','王国强','1234yyy')

产生以下出错信息:

消息513,级别16,状态0,第1行

列的插入或更新与先前的CREATERULE语句所指定的规则发生冲突。

该语句已终止。

冲突发生于

数据库'studentsdb',表'dbo.stu_phone',列'电话号码'。

语句已终止。

试分析:

为什么会产生该出错信息?

如果要实现插入操作,应修改INSERTINTO语句中的哪个值?

phone_rule规则能否对其他操作(如DELETE)进行规则检查?

修改:

INSERT INTO stu_phone(学号,姓名,电话号码)VALUES('0009','王国强','1234567') 

 

phone_rule规则可以对其他操作进行规则检查

2.创建一个规则stusex_rule,将其绑定到stu_phone表的“性别”列上,保证输入的性别值只能是“男”或“女”。

createrulestusex_rule

as@性别in('男','女')

3.使用系统存储过程sp_help查询stusex_rule规则列表,使用sp_helptext查询stusex_rule规则的文本,使用sp_rename将stusex_rule规则更名为stu_s_rule。

sp_helpstusex_rule

Sp_helptextstusex_rule

sp_rename  stusex_rule,stu_s_rule

4.删除stu_s_rule规则。

drop rule stu_s_rule

注意:

stu_s_rule为stusex_rule更名后规则名,是否仍然绑定在stu_phone表的“性别”列上,应如何操作才能删除它。

5.在studentdb数据库中,建立日期、货币和字符等数据类型的默认对象。

(1)创建默认对象df_date、df_char、df_money。

创建日期型默认对象df_date,默认日期为2006-4-12。

--创建日期型默认对象df_date

CREATEDEFAULTdf_date

AS'2006-4-12'

创建字符型默认对象df_char,默认字符为“unknown”

--创建字符型默认对象df_char

CREATEDEFAULTdf_char

as'unknown'

创建货币型默认对象df_money,默认为100元

--创建货币型默认对象df_money

CREATEDEFAULTdf_money

AS‘$100’

(2)输入以下代码,在studentsdb数据库中创建stu_fee数据表。

CREATETABLEstu_fee

(学号char(10)NOTNULL,

姓名char(8)NOTNULL,

学费money,

交费日期datetime,

电话号码char(7))

表stu_fee的数据结构如图1-11所示。

图1-11stu_fee的数据结构

(3)使用系统存储过程sp_bindehult将默认对象df_date、df_char、df_money分别绑定在stu_fee表的“学费”、“交费日期”、“电话号码”列上。

sp_bindefaultdf_money,'stu_fee.学费'

GO

sp_bindefaultdf_date,'stu_fee.交费日期'

GO

sp_bindefaultdf_char,'stu_fee.电话号码'

GO

(4)输入命令,在stu_fee表进行插入操作:

(学号,姓名)values('0001',’刘卫平’)

INSERTINTOstu_fee(学号,姓名)values('0001','刘卫平')

(学号,姓名,学费)values('0001',’张卫民’,$120)

INSERTINTOstu_fee(学号,姓名,学费)values('0001','张卫民',$120)

(学号,姓名,学费,交费日期)values('0001',‘马东‘,$110,’2006-5-12‘)

INSERTINTOstu_fee(学号,姓名,学费,交费日期)

VALUES('0001','马东',$110,'2006-5-12')

分析stu_fee表中插入记录的各列的值是什么?

(5)完成以下代码解除默认对象df_char、df_date、df_money的绑定,并删除之。

 

sp_unbindefault 'stu_fee.电话号码'

drop DEFAULT df_char       

Go

sp_unbindefault 'stu_fee.交费日期'

drop DEFAULT df_date       

go

sp_unbindefault 'stu_fee.学费'      

drop DEFAULT df_money

6.为学生表添加一列,命名为“院系”,创建一个默认对象stu_d_df,将其绑定到学生表的“院系”列上,使其默认值为“信息院”,对学生表进行插入操作,操作完成后,删除该默认对象。

 

1) 

   alter table 学生表   

 add  院系varchar(8)  

2)create default stu_d_df  

as '信息院' 

go 

sp_bindefault stu_d_df ,'学生表.院系'

 go 

(3)sp_unbindefault '学生表.院系'

7.在studentsdb数据库中用CREATETABLE语句创建表stu_con,并同时创建约束。

(1)创建表的同时创建约束。

表结构如图1-12所示。

图1-12要创建的表的结构

约束要求如下:

①将学号设置为主键(PRIMARYKEY),主键名为pk_sid。

②为姓名添加唯一约束(UNIQUE),约束名为uk_name。

③为性别添加默认约束(DEFAULT),默认名称为df_sex,其值为“男”

④为出生日期添加属性值约束(CHECK),约束名为ck_bday,其检查条件为:

出生日期>'1988-1-1’。

CREATETABLEstu_con

(学号char(4),

姓名char(8),

性别char

(2),

出生日期datetime,

家庭住址varchar(50),

constraint PK_sid PRIMARY KEY(学号), constraint uk_name UNIQUE(姓名),

constraint ck_bday check(出生日期>'1988-1-1'),

alter table stu_con

add constraint df_sex default '男' FOR 性别

(2)在stu_con表中插入如表1-1所示的数据记录。

表1-1在stu_con表中插入的数据

学号

姓名

性别

出生日期

家庭住址

0009

张小东

1989-4-6

0010

李梅

1983-8-5

0011

王强

1988-9-10

0012

王强

1989-6-3

分析各约束在插入记录时所起的作用,查看插入记录后表中数据与所插入的数据是否一致?

INSERT INTO stu_con (学号,姓名,出生日期) values('0009','张小东','1989-4-6')

INSERT INTO stu_con (学号,姓名,出生日期) values('0010','李梅','1983-8-5') 

消息547,级别16,状态0,第1 行 

INSERT 语句与CHECK 约束"ck_bday"冲突。

该冲突发生于数据库"studentsdb",表"dbo.stu_con", column '出生日期'。

 

语句已终止。

 

INSERT INTO stu_con (学号,姓名,出生日期) values('0011','王强','1988-9-10')

INSERT INTO stu_con (学号,姓名,出生日期) values('0012','王强','1989-6-3') 

消息2627,级别14,状态1,第1 行 

违反了UNIQUE KEY 约束'uk_name'。

不能在对象'dbo.stu_con' 中插入重复键。

语句已终止

(3)使用ALTER TABLE语句的DROP CONSTRAINT参数项在查询分析器中删除为stu_con表所建的约束。

 

 

     alter table stu_con  

drop constraint df_sex,uk_name,pk_sid,ck_bday

8.用SQL Server管理平台完成实验内容7的所有设置。

9.在查询设计器中,为studentsdb数据库的grade表添加外键约束(FOREIGNKEY),要求将“学号”设置为外键,参照表为student_info,外键名称为fk_sid。

使用系统存储过程sp_help查看grade表的外键信息。

在grade表中插入一条记录,学号为0100,课程编号为0001,分数为78。

观察SQLServer会做何处理,为什么?

如何解决所产生的问题?

使用查询设计器删除grade表的外键fk_sid。

(1)alter table grade

add constraint fk_sid FOREIGN KEY(学号)references student_info(学号) sp_help grade

(2) insert grade values ('0100','0001','78','')

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 解决方案 > 学习计划

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2