实验一创建数据库及关系表数据完整性约束
- 格式:docx
- 大小:754.37 KB
- 文档页数:5
数据库中的数据完整性与约束数据完整性是数据库设计和管理中的重要概念,它确保数据库中存储的数据准确、一致、可靠。
为了保证数据的完整性,数据库引入了各种约束,限制数据的输入和操作,以避免对数据库造成不一致或错误的影响。
一、实体完整性实体完整性是指数据库中的实体必须具有唯一性。
在数据库中,每个记录都代表一个实体,通过定义主键来确保每个实体都能唯一标识。
主键是一个或多个字段的组合,它们的值在整个表中必须唯一。
通过主键约束,确保了每个实体在数据库中的唯一性。
二、域完整性域完整性是指数据库中的每个字段都必须满足一定的约束条件。
常见的域完整性包括数据类型、长度、格式等方面的限制。
例如,在一个存储用户信息的表中,手机号字段的数据类型必须是数字,长度必须是11位,以保证数据的有效性。
三、参照完整性参照完整性是指两个表之间的引用关系必须满足一定的约束条件。
在关系型数据库中,通过外键约束可以实现参照完整性。
外键是一种引用另一个表中主键的字段,用于建立表之间的关联关系。
通过外键约束,确保了数据在引用表和被引用表之间的一致性。
四、用户定义的完整性用户定义的完整性是指根据业务需求,用户对数据库添加的约束。
例如,用户可以定义检查约束来限制某个字段的取值范围,确保数据的合法性。
用户还可以定义触发器来在插入、更新、删除数据时执行一些特定操作,从而保证数据的一致性。
综上所述,数据库中的数据完整性与约束是确保数据准确性和一致性的重要手段。
通过实体完整性、域完整性、参照完整性和用户定义的完整性等约束,可以有效地保证数据库中存储的数据的有效性和可靠性。
数据库管理员和开发人员在设计和管理数据库时,应合理利用这些约束,以确保数据的完整性。
数据库中数据完整性与约束的设计与实现要点数据完整性和约束是数据库设计和实现中非常重要的方面。
通过定义和实施适当的数据完整性约束,可以确保数据库中的数据准确、一致和可靠。
本文将针对数据库中数据完整性和约束的设计与实现要点进行探讨。
1. 数据库中的数据完整性数据完整性是指数据的正确性和一致性。
在数据库中,数据完整性可以通过以下几种方式来保证:1.1 主键约束主键是一个唯一标识数据库表中每一行数据的字段(或字段组合)。
通过为每个表选择合适的主键并将其定义为主键约束,可以确保每一行数据的唯一性。
1.2 外键约束外键用于关联两个表,它可以用来确保表之间的关系的正确性。
通过为引用外键的表添加外键约束,可以防止在关联的表中插入无效的数据,从而维护数据的一致性。
1.3 唯一约束唯一约束用于确保某个字段或一组字段的唯一性。
它可以防止在同一表中插入具有相同值的字段值,从而保持数据的一致性。
1.4 非空约束非空约束用于确保某个字段不为空。
通过将非空约束应用于必填字段,可以防止插入丢失重要数据的空值。
2. 数据库中的数据约束数据约束是一种用于约束数据值范围、格式和类型的方法。
它可以保证数据库中的数据满足预定义的规则和要求。
2.1 默认约束默认约束用于为字段提供默认值。
当插入新行时,如果未给定该字段的值,则默认值将自动应用。
2.2 检查约束检查约束用于对字段的值进行条件限制。
通过定义检查约束,可以确保插入到表中的数据满足指定的条件。
2.3 唯一约束如前所述,唯一约束可用于确保字段或字段组合的唯一性。
2.4 外键约束外键约束不仅用于维护表之间的一致性,还可以通过引用被引用表中的主键来保持数据的完整性。
3. 数据库中的数据完整性和约束的实现要点为了实现数据的完整性和约束,需要注意以下几个重要的实现要点:3.1 合理选择主键选择合适的主键非常重要。
主键应该是唯一的、稳定的并且不可更改的。
设计时应该考虑主键的用途和特性,同时避免过度依赖可能发生变化的字段。
经济管理学院财务管理专业协作者______________ 教师评定_____________实验题目建立表和定义完整性约束、数据操作一、实验目的与实验方法本实验课程的目的:本实验课程的实验方法:二、实验要求1.用CREATE DATABSE命令建立数据库2.用CREATE SCHEMA命令创建模式(自己命名模式名称)3.在定义的模式下,参照教材内容,使用SQL语言创建教材P43—P44面的样本数据库及定义完整性约束4.使用Insert命令完成记录的插入操作,要求分别设计若干违反实体完整性、参照完整性和用户自定义完整性的插入操作,并分析原因。
三、实验结果和数据1.用CREATE DATABSE命令建立数据库2.用CREATE SCHEMA命令创建模式(自己命名模式名称)3.在定义的模式下,参照教材内容,使用SQL语言创建教材P43—P44面的样本数据库及定义完整性约束4.使用Insert命令完成记录的插入操作,要求分别设计若干违反实体完整性、参照完整性和用户自定义完整性的插入操作,并分析原因。
违反实体完整性:违反参照完整性:在执行插入操作时,系统会自动计算院系系列值是7,而院系列参照院系表的编号值,此时在院系表中找不到编号为7的院系。
所以插入操作失败。
违反用户自定义完整性:结果是违反了unique约束,因为院系表名称不允许重复,而名称为“经济管理学院”的院系已经存在,所以不成功。
四、问题与讨论在创建的过程中没有注意括号是用英文括号还是中文括号,所以出现了错误。
应该使用英文括号的。
在同一个数据库中是不能同时创建两个相同的对象的。
心得体会:数据库是一门很难学的课程,而且,我在平时比较少关注这方面的东西,所以,我在做这个实验的时候就觉得十分的困难。
很多的时候我都需要别人的帮助。
我是一个比较粗心的人,因此,我在做这个实验的时候没有留意输入的时候要用英文符号,要加空格。
所以,我总是出现错误,让我觉得很烦恼。
实现数据完整性约束数据完整性约束是指在数据库中确保数据的准确性、一致性和有效性的一组规则和限制。
这些约束可以保护数据库以免受到无效、不一致或重复数据的影响。
通过实施数据完整性约束,可以确保数据库中的数据具有一定的质量和价值,从而增强数据库的可靠性和可用性。
数据完整性约束可以通过多种方式实现,下面是一些常见的方法:1. 主键约束(Primary Key Constraint):主键是一种唯一标识数据库表中每一行的字段(或一组字段),它的值不能重复且不能为空。
通过为表定义主键,并将该字段(或字段组合)设置为主键约束,可以确保表中的每一行都有唯一标识,并且不存在空值。
3. 唯一约束(Unique Constraint):唯一约束用于确保表中的一些字段(或一组字段)的值是唯一的,即在表中不存在重复值。
通过为表中的字段添加唯一约束,可以防止插入重复数据,从而保证数据的一致性。
4. 非空约束(Not Null Constraint):非空约束用于确保表中的一些字段不允许为空值。
通过为字段添加非空约束,可以强制要求在插入或更新数据时必须为该字段提供有效的值,从而防止插入无效数据。
5. 默认约束(Default Constraint):默认约束用于在插入新记录时为字段提供默认值。
通过定义默认约束,可以确保在没有明确赋值的情况下,字段总是具有预先定义的默认值,从而确保数据的完整性。
6. 检查约束(Check Constraint):检查约束用于在插入或更新数据时对字段的值进行验证。
通过定义检查约束,可以限制字段的值必须满足特定的条件,例如数值范围、正则表达式匹配等。
这样可以确保插入或更新的数据满足预期的要求,从而保证数据的有效性和一致性。
为了实现数据完整性约束,数据库管理系统(DBMS)通常提供了相应的语法和功能来定义和应用这些约束。
通过在创建表时使用适当的约束语句,或者在已经存在的表中使用ALTERTABLE语句添加约束,可以实施这些数据完整性约束。
实验名称:数据完整性验证实验实验日期:2023年4月10日实验地点:XX大学计算机实验室实验目的:1. 了解数据完整性的概念和重要性。
2. 掌握数据完整性验证的方法和工具。
3. 提高对数据质量控制和数据管理的认识。
实验原理:数据完整性是指数据的准确、一致和可靠。
在数据管理过程中,数据完整性是保证数据质量的基础。
数据完整性验证是指通过各种方法对数据进行检查,确保数据的准确性和一致性。
实验器材:1. 实验计算机:一台配置较高的计算机,用于运行数据完整性验证工具。
2. 数据库管理系统:如MySQL、Oracle等,用于存储实验数据。
3. 数据完整性验证工具:如SQL Profiler、DataGrip等,用于检测数据完整性问题。
实验步骤:1. 数据准备(1)创建一个数据库,并在数据库中创建一个表,用于存储实验数据。
(2)向表中插入一些数据,包括正常数据和异常数据。
2. 数据完整性验证(1)使用SQL Profiler工具对数据库进行数据完整性验证。
(2)在SQL Profiler中配置监控参数,如监控类型、监控对象等。
(3)启动SQL Profiler,运行数据库操作,如插入、更新、删除等。
(4)观察SQL Profiler的输出结果,检查数据是否发生异常。
3. 结果分析(1)分析SQL Profiler的输出结果,找出数据完整性问题。
(2)根据问题类型,提出解决方案。
实验结果:1. 数据完整性问题(1)在插入异常数据时,发现部分数据未满足数据类型约束。
(2)在更新数据时,发现部分数据未满足唯一性约束。
2. 解决方案(1)针对数据类型约束问题,修改数据类型,确保数据满足约束条件。
(2)针对唯一性约束问题,修改数据,确保数据满足唯一性条件。
实验结论:1. 数据完整性验证对于保证数据质量至关重要。
2. 使用SQL Profiler等工具可以有效检测数据完整性问题。
3. 通过数据完整性验证,可以及时发现并解决数据质量问题,提高数据管理水平。
实验创建数据库表与约束
一、实验目的
1、掌握创建数据库表的方法;
2、学会设置表的主键、外键和建立表之间的关系;
3、学会为表增加约束
二、实验内容
1、创建“StudentDB”数据库,并在数据库中创建三个表:课程表Lessons,学生表Students,成绩表Scores。
各表主要字段如下图所示:
Students:
Lessons:
Scores:
2、设置上述三个表的主键。
建议:Students用“sno”做主键,Lessons用“lno”做主键,Scores用(sno,lno)做主键。
3、分别打开三个表,输入记录数据。
4、为表增加约束:重要列非空,性别sex为“男”或“女”,学分credit在1到5之间,成
绩score在0到100之间。
5、为Scores表设置外键sno和lno,建立三个表之间的主外键关系,并创建数据关系图“guanxi1”。
数据库实验报告姓名学号目录一.实验标题:2二.实验目的:2三.实验内容:2四.上机软件:3五.实验步骤:3(一)SQL Server 2016简介3(二)创建数据库 4(三)创建数据库表 7(四)添加数据17六.分析与讨论: 19一.实验标题:创建数据库和数据表二.实验目的:1.理解数据库、数据表、约束等相关概念;2.掌握创建数据库的T-SQL命令;3.掌握创建和修改数据表的T-SQL命令;4.掌握创建数据表中约束的T-SQL命令和方法;5.掌握向数据表中添加数据的T-SQL命令和方法三.实验内容:1.打开“我的电脑”或“资源管理器”,在磁盘空间以自己的姓名或学号建立文件夹;2.在SQL Server Management Studio中,使用create database命令建立“学生-选课”数据库,数据库文件存储在步骤1建立的文件夹下,数据库文件名称自由定义;3.在建立的“学生-选课”数据库中建立学生、课程和选课三张表,其结构及约束条件如表所示,要求为属性选择合适的数据长度;4.添加具体数据;四.上机软件:SQL Server 2016五.实验步骤:(一)SQL Server 2016简介1.SQL Server 2016的界面2.启动和退出SQL Server 20161)双击图标,即出现SQL Server2016的初始界2)选择“文件”菜单中的“退出”命令,或单击控制按钮中的“×”即可注意事项:1.在退出SQL Server 2016之前,应先将已经打开的数据库进行保存,2.如果没有执行保存命令,系统会自动出现保存提示框,根据需要选择相应的操作(二)创建数据库方法一:1.点击“新建查询”,出现如下对话框2.在空白区域输入创建数据库“学生选课”的代码命令,点击“执行”3.消息框中出现“命令已成功完成”即表示数据库创建成功,在“对象资源管理器”中,右击“数据库”,打开快捷菜单,选择“刷新”命令,在“数据库”向下会出现新创建的数据库“学生选课”方法二:1.右击数据库,在弹出的快捷菜单中选择“新建”2.在弹出的对话框中输入“学生选课”3. 在“对象资源管理器”中,右击“数据库”,打开快捷菜单,选择“刷新”命令,在“数据库”向下会出现新创建的数据库“学生选课”注意事项:数据库名称在服务器中必须唯一,并且符合标识符的规则(三)创建数据库表1.左键点击“学生选课”数据库,再点击“新建查询”,在出现的空白对话框中输入如图代码后点击“执行”,消息框中出现“命令已成功执行”即成功建立好学生、课程、选课三张表2.建立成功后的表格如图所示注意事项:1.T-SQL中创建数据库表的指令格式为:Create table 表名(字段名1 数据类型{identify | not null | null},字段名2 数据类型{identify | not null | null},……)null表示该字段的值可以为控制,空值意味着没有任何存储数据,这是默认参数,当所定义的字段允许空值时,参数null可以忽略not null表示该字段的值不能为空值identify称为计数器,表示该字段的值是一组递增的证书数据。
数据库的完整性约束一、实验目的1.掌握主键约束、外键约束及及check约束的用法;2.掌握默认值约束的应用;二、实验环境已安装SQL Server 企业版的计算机;具有局域网环境,有固定IP;三、实验学时2学时四、实验要求1.熟悉数据库完整性相关概念及约束;2.了解约束、默认值及规则;3.完成实验报告;五、实验内容及步骤以系统管理员身份登录到SQL Server服务器,并使用T-SQL语句实现以下操作;1.请用至少2种方法定义stu数据库中student表的主键sno;2.将数据库stu的表course的cno字段定义为主键,约束名称为cno_pk;3.为表course中的字段cname添加唯一值约束;4.将数据库stu的表sc的sno及cno字段组合定义为主键,约束名称为sc_pk;5.对于数据表sc的sno、cno字段定义为外码,使之与表student的主码sno及表course的主码cno对应,实现如下参照完整性:1)删除student表中记录的同时删除sc表中与该记录sno字段值相同的记录;2)修改student表某记录的sno时,若sc表中与该字段值对应的有若干条记录,则拒绝修改;3)修改course表cno字段值时,该字段在sc表中的对应值也应修改;4)删除course表一条记录时,若该字段在在sc表中存在,则删除该字段对应的记录;5)向sc表添加记录时,如果该记录的sno字段的值在student中不存在,则拒绝插入;6. 定义check约束,要求学生学号sno必须为9位数字字符,且不能以0开头,第二三位皆为0;(不用做)7. 定义stu数据库中student表中学生年龄值在16-25范围内;8. 定义stu数据库中student表中学生姓名长度在2-8之间;9. 定义stu数据库中student表中学生性别列中只能输入“男”或“女”;10. 定义stu数据库student表中学生年龄值默认值为20;11. 修改student表学生的年龄值约束可以为15-30范围内;(不用做)12. 删除上述唯一值约束、外键约束及check约束;13.向下列三个表中分别插入如下数据:SC表Course 表14、在上面的基础上分别向studentinfo 数据库中的student, course, sc 表中添加少8条数据。
关系型数据库中的数据完整性与约束条件研究在当今信息时代,数据是企业和组织的重要资产,因此保障数据库中数据的完整性就显得格外重要。
关系型数据库是当今最流行的数据库类型之一,而其中数据完整性与约束条件就是确保数据的正确性和合法性的重要因素。
数据完整性是指数据库中的数据符合定义的规则和规范,而不会受到无效数据、不一致数据、冗余数据等各种异常干扰。
数据完整性由数据库管理系统(DBMS)通过设计并应用特定的约束条件来保障。
首先,关系型数据库中最常见的数据完整性约束条件是主键约束。
主键约束保证了数据库中每个记录的唯一性,通过限制某一列或多列的取值范围,确保每行数据都能被唯一地识别和访问。
主键约束可防止重复插入数据,保证数据库的严密性。
除了主键约束,关系型数据库还支持外键约束。
外键约束定义了不同表之间的依赖关系,通过将关联表的主键作为外键引用到其他表中,确保在数据库中没有无效的引用。
外键约束可以实现关系和一致性的维护,防止数据的不一致性和冗余。
另外一个重要的数据完整性约束条件是唯一约束。
唯一约束保证了指定列中的数据是唯一的,不允许有重复值存在。
唯一约束可以防止数据库中出现重复的数据,提高数据的准确性和质量。
除了上述约束条件,关系型数据库还提供了一系列数据完整性的约束条件,如非空约束、默认值约束、检查约束等。
非空约束要求指定列中的值不能为空,确保数据不会缺失。
默认值约束为某一列设置了默认值,在插入数据时,如果没有指定该列的值,则会自动使用默认值。
检查约束要求某一列的数据满足特定的条件,舍弃不符合要求的数据。
总结来说,关系型数据库中的数据完整性与约束条件是确保数据正常和有效存储的关键因素。
通过主键约束、外键约束、唯一约束以及其他的约束条件,可以确保数据的唯一性、一致性和合法性,提高数据库的质量和可靠性。
为了确保数据完整性和约束条件的有效性,在设计关系型数据库时需要仔细考虑各个表之间的关系,确保合适的约束条件应用于各个字段。
关系数据库的完整性约束关系数据库是一种常用的数据库模型,它使用表格来存储和组织数据。
在关系数据库中,完整性约束是一种重要的机制,用于确保数据的一致性和准确性。
本文将介绍关系数据库的完整性约束的定义、类型以及它们在数据库设计和数据管理中的作用。
一、完整性约束的定义完成性约束是指定义在关系数据库表上的规则,用于保证数据的完整性。
它可以限制某些列的取值范围、规定表之间的关系、强制规则和业务规则等。
通过定义完整性约束,可以防止不一致、不准确或不符合业务规则的数据进入数据库。
二、完整性约束的类型1. 实体完整性约束实体完整性约束用于确保每一行数据在主键列上具有唯一的值,并且不为空。
主键是关系数据库中用于唯一标识每一行数据的列或列组合。
2. 引用完整性约束引用完整性约束用于确保表之间的关系的一致性。
它结合了外键和主键的概念,确保在外键列中的值必须在参照表的主键列中存在。
这样可以防止不一致的关系建立或错误的数据引用。
3. 域完整性约束域完整性约束用于限制某些列的取值范围。
可以通过定义数据类型、长度、格式等约束来确保数据的准确性和一致性。
4. 用户自定义完整性约束用户自定义完整性约束是根据特定业务需求定义的约束规则。
可以使用触发器、存储过程或触发器等数据库对象来实现自定义完整性约束。
5. 断言完整性约束断言完整性约束是在SQL标准中定义的,用于在关系数据库中表示某种条件必须成立。
断言可以在表创建时定义或随后添加,以确保数据满足特定条件。
三、完整性约束的作用1. 数据的一致性和准确性:通过完整性约束,可以限制数据的取值范围和关系,确保数据的准确性和一致性。
2. 数据的安全性:完整性约束可以防止数据被非法篡改、删除或插入不符合规定的数据。
3. 业务规则的保护:通过完整性约束,可以确保数据库中存储的数据符合特定的业务规则。
4. 避免错误的数据关联:引用完整性约束可确保外键的合法性,防止不一致的数据关联。
5. 数据的可靠性和可维护性:通过定义完整性约束,可以为数据库提供可靠的结构和规范,便于数据的管理和维护。
实验一创建数据库及关系表数据完整性约束
The following text is amended on 12 November 2020.
实验一创建数据库及关系表、数据完整性约束
一、实验目的
1.掌握SQL Server数据库管理系统的使用,能够在该环境中进行日常数据库操作;
2.掌握在SQL Server中使用图形化工具创建数据库的方法;
3.掌握建立关系表的语句,掌握定义主码约束及外码约束的语句;
4.掌握修改表结构的语句。
5.掌握数据完整性约束的功能。
二、实验内容和步骤
1.创建符合如下条件的数据库:
数据库的名字为:Students
数据文件的逻辑文件名为:Students_dat,存放在用户盘某目录下;
文件的初始大小为:5MB;增长方式为自动增长,每次增加1MB。
实验结果:
2.在已建立的Students数据库中,确定出各表中的数据类型,写出创建满足下述条件的四张表的SQL语句,并查看执行结果。
实验结果:
3.写出实现如下操作的SQL语句,并查看执行结果:
(1)在选课表中添加一个新的修课类别列:列名为:选课类别,类型为char(4)。
(2)将课程表中的学分列的类型改为:tinyint(微整型,取值范围在0~255)。
(3)删除学生表的专业列。
(4)为教师表添加主码约束,其主码列为:教师号。
实验结果:
4.在Students数据库中,编写建立满足完整性要求的定义表的SQL语句,执行并观察执行结果。
(1)图书表,结构如下:
书号:统一字符编码定长类型,长度为6,主码,
书名:统一字符编码可变长类型,长度为30,非空,
第一作者:普通编码定长字符类型,长度为10,非空,
出版日期:小日期时间型,小于等于当前系统日期,(用getdate()实现)
印刷数量:小整型,取值范围:1000~5000,默认为4000,
价格:定点小数,小数部分一位,整数部分3位。
实验结果:
(2)书店表,结构如下:
书店编号:统一字符编码定长类型,长度为6,主码,
店名:统一字符编码可变长类型,长度为30,非空,
电话:普通编码定长字符类型,12位长,取值形式:010-8位数字
地址:普通编码可变长字符类型,40位长。
前两个字符必须是:北京。
实验结果:
(3)图书销售表,结构如下:
书号:统一字符编码定长类型,长度为6,非空,
书店编号:统一字符编码定长类型,长度为6,非空,
销售日期:小日期时间型,非空,默认值为系统当前日期,
销售数量:微整型,取值大于0,主码(书号,书店编号,销售日期);
书号为引用“图书表”的外码;书店编号为引用“书店表”的外码。
实验结果:
5. 执行下列两条数据插入语句,是否都能执行成功为什么
INSERT INTO Book
VALUES('T0001','数据库系统基础','张三','2010-2-1', 3000,
实验结果:能执行
INSERT INTO Book
VALUES('T0002','计算机网络','张三','2010-1-1', 500,
实验结果:不能执行,原因:印刷数量小于1000
6. 执行下列数据插入语句,是否执行成功为什么
INSERT INTO Store VALUES('S001','新华书店',,'北京市海淀区')
实验结果:不能执行,原因:电话号码不符合标准
7. 执行一条数据插入语句,是否执行成功为什么
INSERT INTO Sale(书号,书店编号,销售数量)VALUES('T0001','S001',20)
实验结果:不能执行,原因:store是sale外键,其中store并没有添加进数据。
三、实验源码
CREATE table Student(
学号CHAR(7)primary key,
姓名NCHAR(5)not null,
性别NCHAR(1),
年龄TINYINT,
所在系NVARCHAR(20),
专业NVARCHAR(20)
)
CREATE table Course(
课程号CHAR(6)primary key,
课程名NVARCHAR(20)NOT NULL,
学时数TINYINT,
学分TINYINT
)
CREATE TABLE SC(
学号CHAR(7)NOT NULL,
课程号CHAR(6)NOT NULL,
成绩TINYINT,
PRIMARY KEY (学号,课程号),
FOREIGN KEY (学号)REFERENCES Student(学号),
FOREIGN KEY (课程号)REFERENCES Course(课程号)
)
CREATE table Teather(
教师号CHAR(7)not null,
教师名NCHAR(5)not null,
所在部门NVARCHAR(20),
工资Smallmoney,
出生日期Smalldatetime
)
select*from Student
select*from Course
select*from SC
select*from Teather
ALTER TABLE SC
ADD选课类别char(4)
ALTER TABLE Course
ALTER COLUMN学分tinyint
ALTER TABLE Student
DROP COLUMN专业
ALTER TABLE Teather
ADD constraint ys primary key(教师号)
CREATE table Book(
书号NCHAR(6)primary key,
书名Nvarchar(30)not null,
第一作者CHAR(10)not null,
出版日期smalldatetime check(出版日期<getdate()),
印刷数量Smallint check(印刷数量< 5000 and印刷数量> 1000)default (4000),
价格decimal(3,1)
)
CREATE table Store(
书店编号NCHAR(6)primary key,
店名NVARCHAR(30)NOT NULL,
电话Char(12)check(电话like'010-[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]'),地址Varchar(40)check(地址like'北京%')
)
Create table Sale
(
书号NCHAR(6)not NULL,
书店编号Nchar(6)not NULL,
销售日期Smalldatetime default getdate(),
销售数量tinyint check(销售数量> 0),
primary key (书号,书店编号,销售日期),
foreign key (书号)references Book(书号),
foreign key (书店编号)references Store(书店编号)
)
INSERT INTO Book
VALUES('T0001','数据库系统基础','张三','2010-2-1', 3000,
INSERT INTO Book
VALUES('T0002','计算机网络','张三','2010-1-1', 500,
INSERT INTO Store VALUES('S001','新华书店',,'北京市海淀区')
INSERT INTO Sale(书号,书店编号,销售数量)VALUES('T0001','S001',20)
四、实验心得
经过这次实验掌握SQL Server数据库管理系统的基本使用,复习了建立关系表的语句,定义主码约束及外码约束的语句,和修改表结构的语句。
了解了数据完整性约束的功能。
希望下次实验能够学到更多数据库的知识。