数据库完整性代码
数据库实验4 索引、数据完整性与安全性

实验四索引、数据完整性与安全性一、实验目的(1) 掌握利用SQL Server Management Studio和SQL语言建立、删除索引的方法;(2) 掌握利用SQL Server Management Studio和SQL语言实现数据完整性的方法;(3) 掌握在SQL Server Management Studio中实现数据安全性管理的方法。
二、实验原理1.索引在关系型数据库中,索引是一种可以加快数据检索的数据库结构。
SQL Server系统中主要有两种类型的索引,即聚集索引、非聚集索引。
(1)聚集索引聚集索引定义了数据在表中存储的物理顺序。
一个表只能定义一个聚集索引。
(2)非聚集索引非聚集索引并不存储表数据本身。
相反,非聚集索引只存储指向表数据的指针,该指针作为索引键的一部分,因此,在一个表中同时可以存在多个非聚集索引。
(3)利用SQL命令建立索引简化语法格式:CREATE [UNIQUE] [CLUSTERED|NONCLUSTERED]INDEX index_name ON {table|view}(column|ASC|DESC][,…n])其中:UNIQUE。
可选。
该选项用于通知SQL Server索引中列出的列的值是每行唯一的。
如果试图插入重复的行,则该选项会强制SQL Server返回一个错误信息。
CLUSTERED或NONCLUSTERED。
可选。
如果这两个选项都没有被明确列出,则默认将索引创建为NONCLUSTERED(非聚集索引)。
(4)通过SQL命令删除索引语法格式:DROP INDEX ‘table.index|view.index’[,…n]2.表主键和UNIQUE约束表主键通过表数据中一个列或者多个列组合的数据来唯一标识表中的每一行数据。
即表主键就是用来约束数据表中不能存在相同的两行数据。
在SQL Server系统中,定义表的主键可以在创建表的同时定义,也可以给已有的表添加主键。
MySQL数据库的数据完整性与约束设置

MySQL数据库的数据完整性与约束设置引言MySQL数据库是一种流行的关系型数据库管理系统,广泛应用于各种业务领域。
数据完整性是数据库的重要特性之一,它保证数据库中的数据能够符合预期的要求,有效地避免了数据的冗余和错误。
本文将探讨MySQL数据库中的数据完整性和约束设置,并介绍如何在数据库设计和操作中充分利用这些功能。
数据完整性的概念和意义数据完整性是指数据库中的数据满足各项约束条件,不出现意外的错误和矛盾。
它保证了数据的准确性和一致性,提高了数据处理的效率和可靠性。
数据完整性主要包括实体完整性、域完整性、参照完整性和用户自定义完整性等方面。
实体完整性是指数据库表中的每个记录都能够唯一地标识一个实体。
在MySQL中,可以通过定义主键来确保实体的唯一性。
主键是一列或多列组成的标识符,它可以用于唯一地标识每条记录,并保证表中不会出现重复的数据。
通过主键的使用,可以避免数据冗余和不一致的问题。
域完整性是指每个数据字段的值必须符合规定的域范围和约束条件。
在MySQL中,可以通过定义列的数据类型、长度和默认值等属性来保证域完整性。
例如,如果一个字段的数据类型为整数类型,那么它的值就只能是整数,而不能是字符串或其他类型的数据。
通过域完整性的设置,可以有效控制数据的类型和范围,避免了无效数据的存储。
参照完整性是指数据库中的外键和参照表之间的关联关系不能被破坏。
在MySQL中,可以通过定义外键来保证参照完整性。
外键是指一个表中的一个字段引用了另一个表中的字段,这样可以建立起两个表之间的关联关系。
通过外键的使用,可以防止无效的外键引用和关联表的数据不一致,确保数据的一致性和有效性。
用户自定义完整性是指根据具体业务需求,定义一些适合自己业务规则的完整性约束。
在MySQL中,可以通过定义触发器、存储过程和视图等对象来实现用户自定义完整性。
触发器可以在数据插入、更新或删除时触发一系列操作,从而对数据进行特定的验证和处理。
第5章sql数据库完整性约束

5.2.4 默认值(DEFAULT)约束
默认约束是指在用户未提供某些列的数据时,数据库 系统为用户提供的默认值。从而简化应用程序代码和提高 系统性能。 表的每一列都可包含一个DEFAULT定义。可以修改或 删除现有的DEFAULT定义,但必须首先删除已有的 DEFAULT定义,然后通过新定义重新创建。 1.利用Management Studio定义(删除)default约束 步骤1:右键要建立default约束的表选择“修改”。 步骤2:在弹出的窗口中对应字段的“默认值或绑定”处 输入默认值。 步骤3:点击保存即可。
PRIMARY KEY约束在表中定义一个主键,唯一的标 识表中的行。一个表只能有一个PRIMARY KEY约束。
当向表中的现有列添加PRIMARY KEY约束时,SQL Server将检查列中现有的数据以确保现有数据遵从主键的 规则,即无空值、无重复值。 每个表都应有一个主键。主键可以是一列或列组合。
CREATE TABLE kc_new (5-4)
(课程号 CHAR(4) NOT NULL CONSTRAINT pk_kch1 PRIMARY KEY, 课程名 CHAR(16) NOT NULL CONSTRAINT ix_kcm1 UNIQUE,
学分 SMALLINT,
数据库管理与开发项目教程(SQL Server 2019)第3版 项目八 实现数据完整性

/*定义列名、数据类型、
是否空值
[[CONSTRAINT check_name] CHECK (logical_expression)][,…n]) /*定义
CHECK约束
【例8-1】 在xs数据库中创建XSXX表,并定义CHECK约束。
10
项目8 实现数据完整性 ->任务1 实现域完整性
任务1-2 CHECK约束
项目8 实现数据完整性 ->任务1 实现域完整性
任务1-2 CHECK约束
CHECK约束实际上是字段输入内容的验证规则,表示一个字段的输入内容
必须满足CHECK约束的条件,如果不满足,数据就无法正常输入。
CHECK约束可以作为表定义的一部分在创建表时创建,也可以添加到现有表中。
表和列可以包含多个CHECK约束。允许修改或删除现有的CHECK约束。
【项目描述】
为xs数据库创建CHECK约束、规则、DEFAULT约束、默认值对象、索引、PRIMARY KEY约束、 UNIQUE约束、FOREIGN KEY约束实现数据完整性保护。
项目8 实现数据完整性
【项目分析】 项目4在数据库xs中建立了数据表,在向表中输入数据时,由于种种原因,有
时会输入无效或错误的信息。比如,对不同的学生输入了相同的学号,“性别” 字段的值输入了非法数据,相同的数据行被多次输入,学生成绩表中出现了学生 档案表中不存在的学号等。之所以会出现这些错误信息,是因为没有实现数据完 整性。为避免此类情况发生,本项目主要介绍如何通过实施数据完整性来解决上 述问题,以此保证数据输入的正确性、一致性和可靠性。
《SQL SERVER2019项目开发教程 》
项目8 实现数据完整性
项目8 实现数据完整性
数据库的安全性、完整性、并发控制和恢复

数据库的安全性、完好性、并发控制和恢复为了保证数据库数据的安全靠谱性和正确有效, DBMS 一定供给一致的数据保护功能。
数据保护也为数据控制,主要包含数据库的安全性、完好性、并发控制和恢复。
数据库的安全性数据库的安全性是指保护数据库以防备不合法的使用所造成的数据泄漏、改正或损坏。
计算机系统都有这个问题,在数据库系统中大批数据集中寄存,为很多用户共享,使安全问题更加突出。
在一般的计算机系统中,安全举措是一级一级设置的。
在 DB 储存这一级可采纳密码技术,当物理储存设施失窃后,它起到保密作用。
在数据库系统这一级中供给两种控制:用户表记和判定,数据存取控制。
在 ORACLE 多用户数据库系统中,安全体制作以下工作:防备非受权的数据库存取;防备非受权的对模式对象的存取;控制磁盘使用;控制系统资源使用;审计用户动作。
数据库安全可分为二类:系统安全性和数据安全性。
系统安全性是指在系统级控制数据库的存取和使用的体制,包含:有效的用户名 /口令的组合;一个用户能否受权可连结数据库;用户对象可用的磁盘空间的数目;用户的资源限制;数据库审计是不是有效的;用户可履行哪些系统操作。
数据安全性是指在对象级控制数据库的存取和使用的体制,包含:哪些用户可存取一指定的模式对象及在对象上同意作哪些操作种类。
在 ORACLE 服务器上供给了一种随意存取控制,是一种鉴于特权限制信息存取的方法。
用户要存取一对象一定有相应的特权授给该用户。
已受权的用户可随意地可将它受权给其余用户,因为这个原由,这类安全性种类叫做随意型。
ORACLE 利用以下体制管理数据库安全性:数据库用户和模式;特权;角色;储存设置和空间份额;资源限制;审计。
数据库的存取控制ORACLE保护信息的方法采纳随意存取控制来控制所有用户对命名对象的存取。
用户对对象的存取受特权控制。
一种特权是存取一命名对象的同意,为一种规定格式。
ORACLE 使用多种不一样的体制管理数据库安全性,此中有两种体制:模式和用户。
第二章数据库的完整性控制数据完整性(DataIntegrity)是指数据的精确

第二章数据库的完整性控制数据完整性(Data Integrity)是指数据的精确性(accuracy)和可靠性(reliability),它是防止数据库中存在不符合语义规定的数据和防止因错误的信息的输入造成无效操作或错误信息而提出的,保证在一个应用程序更新数据的过程中数据的语义正确性。
数据完整性主要分为三类:实体完整性(Entity Integrity),参照完整性(Referential Integrity)以及用户定义的完整性(User-defined Integrity),其中用户定义的完整性主要包括域完整性(Domain Integrity)和其他自定义完整性。
为维护数据库德完整性,数据库管理系统(DBMS)必须提供一种机制来检查数据库中的数据,看其是否满足语义规定的条件。
这些加在数据库数据上的语义约束条件称为数据库完整性规则,它们作为模式的一部分存入数据库中。
完整性控制是指对数据库进行更新操作,要遵守完整性规则,才能保证数据的语义正确性,防止数据库中存在不符合语义的数据。
目的是在合法用户访问数据库的过程中,保证数据的正确性和准确性。
完整性检查机制是指在DBMS中检查数据是否满足完整性条件的机制。
由DBMS在执行更新动作时,检查是否满足预定的完整性约束条件,来进行控制。
广义的完整性控制包括故障恢复、并发控制。
而一般所指的完整性控制是指基于数据库的完整性约束规则,如:实体完整性、引用完整性等。
SQL中两种主要的数据完整性控制机制是指完整性约束规则的定义和检查以及触发器(Trigger)机制。
完整性控制机制应具有三个功能:(1)定义功能,即提供定义完整性约束条件的机制;(2)检查功能,即检查用户发出的操作请求书否违反了约束条件;(3)如果发现用户操作请求使数据违背了完整性约束条件,则采取一定的动作来保证数据的完整性。
完整性控制机制的工作原理基本上分为两类,一种是定义完整性时就立刻进行检查的,例如实体完整性的定义;另外一种是定义完整性之后进行检查的,例如参照完整性的定义。
数据完整性

3.5 数据完整性在数据库中数据完整性是指保证数据正确的特性,一般包括实体完整性、域完整性、参照完整性。
一、实体完整性是保证表中记录唯一的特性。
即在一个表中,不能有重复的纪录。
候选关键字:如果一个字段的值或几个字段的值能够唯一标识表中的一条记录,这样的字段称为侯选关键字。
主关键字:在一个表中可能会有几个具有这种特性的字段或者字段的组合,这时从中选择一个作为主关键字。
在VFP中将主关键字称做主索引,将侯选关键字称为侯选索引。
实现方法:在VFP中利用主关键字(主索引)或候选关键字(候选索引)来保证表中记录的惟一性。
例1. 打开数据库“成绩管理”,为学生表中的“学号”字段建立主索引(升序)。
二、域完整性1.域:列的取值的范围(EG:数学中的定义域)域完整性:列的取值范围合理性我们以前在创建表的时候指定不同的数据类型和宽度来限制字段的取值类型和取值范围,但这些还远远不够。
我们需要进一步对列里能输入什么样的数据严格要求。
2.实现域完整性的方法:设置列的有效性规则,设置列的默认值⑴设置列的有效性规则例2. 设置“成绩管理”数据库中“学生”表中年龄字段的有效性规则:要求学生表中的年龄必须在15-22之间,否则就认为输入无效!并提示“年龄只能在15-22岁之间!”例3. 设置“学生”表中系部字段的有效性规则:要求系部列的取值必须是四个系之一,如果输入其他值就认为输入无效!并提示“该系部名不存在!”例4.设置“成绩”表中成绩的有效性规则为:成绩只能在0-100分之间,如果用户输入错误,则提示“成绩不在范围内!”⑵为列设置默认值例5.对“学籍”表进行修改,设置“入学日期”的默认值为2009-08-26,然后打开表,输入一条新记录,观察现象例6. 对“学生”表进行修改,设置“系部”列的默认值为基础部,然后打开表,使用Append命令输入一条新记录,观察现象三、参照完整性1.思考:⑴如果同学们在填学生表的时候将自己的班级名称写错了, 写成了一个学校中根本不存在的班级, 这样的结果肯定是错误的。
数据库完整性(好)资料重点

❖ 参照完整性的常见实现机制包括:
▪ 外键(Foreign Key)、检查(Check)、触发器(Trigger);存 储过程(Stored Procedure)
❖ 常见的实现机制包括:
▪ 规则(Rule)、创建数据表时的所有约束(Constraint)、触发 器(Trigger)、存储过程(Stored Produre);
二、在SQL Server 2005中实现数据完整性
❖ SQL Server 2005提供了完善的数据完整性机制,主 要包括规则、默认值和约束3类;
第六章 数据库完整性
授课教师:刘跃娟 2013-12-6
数据库完整性
❖ 数据是数据库的核心,数据的正确和完整与否将直接影响数据 库的使用。
❖ 数据的完整性和安全性是两个不同概念;
▪ 数据的安全性
➢ 保护数据库防止恶意的破坏和非法的存取 ➢ 防范对象:非法用户和非法操作
▪ 数据的完整性
➢ 防止数据库中存在不符合语义的数据,也就是防止数据库中存在不正 确的数据
❖ 实体完整性:在现实世界中,任何一个实体都有区别于其他实 体的特征,即在数据库中,所有的记录都应该有惟一的标识, 这就是实体完整性的含义(规则2.1:实体完整性规则)。
❖ 常见的实体完整性机制包括:
▪ 主键(Primary Key);惟一码(Unique);
2)参照完整性
❖ 参照完整性是指在两个表的主键和外键之间数据的完整性,其 含义包括:
➢ 防范对象:不合语义的、不正确的数据
本次课内容
一. 数据完整性概述 二. 在SQL Server 2005中实现数据完整性
数据库应用基础第五章数据完整性

5.2 约束的类型
1 PRIMARY KEY 约束 2 FOREIGN KEY 约束 3 UNIQUE 约束 4 CHECK 约束 5 DEFAULT 约束
13
约束是一种强制数据完整性的 book_id borrower_id lend_date back_date
标准机078制9 。 960651
[[CONSTRAINT constraint_name] {PRIMARY KEY
所在列的数据类型
[CLUSTERED|NONCLUSTERED]
创建约[C束LU的S列|TUE的RN名EIQD称|UNEONCLUSTERED] |[FOREIGN KEY] REFERENCES新建约束的名称
ref_table [(ref_column)]
(3)引用完整性 引用完整性用于在输入或删除记录
时,例:保对持于表之Lib间ra已ry定_D义B数的据关库系中。的
book_info 表和 class 表,引用完整性 基于 book_info 表中的外键 (class_id) 与 class 表中的主键 (class_id) 之间 的关系 。
8
1 数据完整性的类型
{(column_name[,...])}
24
② FOREIGN KEY 约束
ALTER TABLE table_name
被FOREIGN
ADD CONSTRAINT constrainKtE_Yn约a束m参e 照的表的名
FOREIGN KEY {(column_nam称e[,...])} REFERENCES ref_table {(column_name[,...])} [ON DELETE {CASCADE|NO ACTION}] [ON UPDATE {CASCADE|NO ACTION}]
第10章 数据完整性-数据库原理与应用教程(Oracle 12c版)-赵明渊-清华大学出版社

例如,对于stsys数据库中student表,sno列作为主键,每一个学 生的sno列能唯一地标识该学生对应的行记录信息,通过sno列建立 主键约束实现student表的实体完整性。
3.参照完整性
参照完整性保证主表中的数据与从表中数据的一致性,又称为 引用完整性,参照完整性确保键值在所有表中一致,通过定义主键 (PRIMARY KEY)与外键(FOREIGN KEY)之间的对应关系实现参照 完整性。
Oracle使用完整性约束机制以防止无效的数据进入数据库的基 表,如果一个DML语句执行结果破坏完整性约束,就会回滚语句并 返回一个错误。通过完整性约束实现数据完整性规则有以下优点:
●完整性规则定义在表上,存储在数据字典中,应用程序的任何 数据都必须遵守表的完整性约束。
●当定义或修改完整性约束时,不需要额外编程。
主键(PRIMARY KEY):表中能唯一标识每个数据行的一个或 多个列。
外键(FOREIGN KEY):一个表中的一个或多个列的组合是另 一个表的主键。
数据库原理与应用教程
(Oracle 12c 版)
4
10.1 数据完整性概述
例如,将student表作为主表,表中的sno列作为主键,score表作为 从表,表中的sno列作为外键,从而建立主表与从表之间的联系实现参 照完整性,student表和score表的对应关系如表10.1、和表10.2所示。
● CHECK约束,检查约束,现域完整性。
● NOT NULL约束,非空约束,实现域完整性。
● PRIMARY KEY约束,主键约束,实现实体完整性。
● UNIQUE KEY约束,唯一性约束,实现实体完整性。
● FOREIGN KEY约束,外键约束,实现参照完整性。
数据库完整性

数据库完整性本节要点:实体完整性参照完整性⽤户定义的完整性完整性约束命名⼦句触发器数据库的完整性是指数据的正确性和相容性。
例如,学⽣的学号必须唯⼀;性别只能是男或⼥;本科学⽣年龄的取值范围为14~50的整数;学⽣选的课程必须是学校开设的课程;学⽣所在的院系必须是学校已经成⽴的院系等。
数据的完整性和安全性是两个不同概念。
为维护数据库的完整性,DBMS必须:提供定义完整性约束条件的机制提供完整性检查的⽅法违约处理1 实体完整性1.1 实体完整性定义关系模型的实体完整性在CREATE TABLE中⽤PRIMARY KEY定义。
对单属性构成的码有两种说明⽅法,⼀种是定义为列级约束条件,另⼀种是定义为表级约束条件。
对多个属性构成的码只有⼀种说明⽅法,即定义为表级约束条件。
⽰例:将Student表中的Sno属性定义为码(单属性构成的码)(1)在列级定义主码CREATE TABLE Student(Sno CHAR(9) PRIMARY KEY,Sname CHAR(20) NOT NULL,Ssex CHAR(2) ,Sage SMALLINT,Sdept CHAR(20));(2)在表级定义主码CREATE TABLE Student(Sno CHAR(9),Sname CHAR(20) NOT NULL,Ssex CHAR(2) ,Sage SMALLINT,Sdept CHAR(20),PRIMARY KEY (Sno));⽰例:将SC表中的Sno,Cno属性组定义为码(多属性构成的码)CREATE TABLE SC(Sno CHAR(9) ,Cno CHAR(4) ,Grade SMALLINT,PRIMARY KEY (Sno,Cno) /*只能在表级定义主码*/);1.2 实体完整性检查和违约处理插⼊或对主码列进⾏更新操作时,RDBMS⾃动进⾏检查:1. 检查主码值是否唯⼀,如果不唯⼀则拒绝插⼊或修改2. 检查主码的各个属性是否为空,只要有⼀个为空就拒绝插⼊或修改2 参照完整性2.1 参照完整性定义关系模型的参照完整性在CREATE TABLE中⽤FOREIGN KEY短语定义哪些列为外码,⽤REFERENCES短语指明这些外码参照哪些表的主码。
数据完整性在数据库应用系统中的设计与实现

4 默认 ( E A L . D F U T)约 束 。
它 为表 中某 列建 立一 个默 认值 , 当用户插 入 记录 是 ,如 果没 有 为该 列提供 输入 值 , 统 自动采用 默 认值 。 系 默认 值可 以使 常量 、 内置 函数或表 达式 ,采 用默 认约 束可 以提 高输入 记录 的速 度 。 5 外键 (OE G E )约束 。 . FR INK Y 外键 为 一个表 中的一 列或 列组合 ,虽 不是 该表 的主 键 ,但却 是 另一 个表 的主键 。通过 外键 约束 可 以为相关 联 的两个 表建 立联 系 ,实 现数据 的引用 完整性 ,维 护表 之 间数据 的一致 性关 系 。 ( )使 用规 则 实现数 据完 整性 二 规 则 是 一种 数 据 库 对 象 ,用 于 限制 输 入值 的取 值 范 围 。 与 C EK约束 比较 ,规 则更 加简 明 ,可 以在 建表 时 由 C ET AL HC R AET BE 语句 将其 作 为表 的一 部分进 行指 定 ,在一 个列 上智 能应 用一 个规 ( )实体 的完整 性 一 则 ,并 且规则 只 需定 义一 次可 以多次 应用 多个 表或 多个 列 ,也可 实体 即为数 据库 中表的记 录。 在表 中, 每一条记 录都需要 非空 , 以应 用 到用户 定义 的数据类 型上 。触 发器 是一 种 实施 复杂 的完整 并且 键值不 重复 ,保证 了数据所代 表的任 何事物都不 存在重 复。 性 约束 的有效 方法 ,当对它 所保 护 的数据 进行 修 改时 自动激 活 , ( )域 完整 性 二 防 止对数 据进 行不 正确 、未授 权 或不 一致 的修 改 。 在使 用之 前 ,采用 CE T UE r l—a e 行创 建 ;然后 R AE RL u enm 进 组成 记录 的 列成 为域 。表示 输入 表 中指定 列对 的数 据必 须具 有 正确 的数据 类 型、格 式和 有效 的数据 范 围 。 绑 定至 列或用 户 定义 的数据 类 型上 ,当某 个字 段不 再 需要规 则对 ( )引用完 整性 三 其 输入 的数据 进行 限制 时 , 以通 过 s—n idu e“ 可 p ub nr l 表名 . 字段 对于 有关 联 的两个 或两 个 以上的表 ,通 过使 用主 键和 外键 或 名 ”进行 删除 。 主键 和 唯一键 之 间的关 系 , 使得 表 中的键值 在所 有表 中保 持一 致 。 ( )使 用默 认值 实现数 据完 整性 三 ( )用 户定 义 的完 整 性 四 默认 也是 党项 表 中输入 记录 时 ,没有 为某 列提供 输入 值 ,如 表示 在应 用领 域应 该遵 守 的约束 条件 。允许 用户 定义 不属 于 果该 列被 绑定 了默 认对 象 ,系统 会 自动将 其值付 给 该列 。与 规则 其他 人和 完整 性分类 的特 定业 务规 则 。 相似 ,包 含默 认 的创建 、绑 定 、解绑 和删 除 ,既可 以在 查询 分析 二 、数据 完整性 的设 计 与实现 器 中完成 ,也 可 以在 企业 管理 其 中完成 。 为 了保证存 放数 据 的正确 性和 一致 性 ,SLSr e Q e vr可 以对 数 三 、结束 语 据施 加一 个或 多个 数据 完整 性约 束 。这 些约 束 限制 了对数 据库 的 数据 的完 整性 是数据 库应 用 系统 的基本 功能 。在 SLsr e Q e vr 数据 值 ,或者 限制 了数据 库修 改所 产生 的数 据值 ,或 限制 了对数 数 据 库系 统中 ,可 以根据 具体 情 况 ,灵活采 用一 种或 多种 方法 建 据库 中某 些值 的修 改 。 立 数 据完 整性 的机 制 ,不仅可 以拒 绝 非法数 据 的提交 ,而 且保 证 用 户 及时 得到操 作 反馈信 息 ,提 高系统 数据 的可靠 性和 安全 性 。 ( )使用 约束 实现 数据 完整性 一 约束 是 SL Sr e 提 供 的 自动 强制 数据完 整性 的方 式之 一 , Q ev r 参考 文献 : 通过 定义 列的取 值规 则维 护数据 的完 整 性 。 f 李 芳 . L Sre 中数 据 完 整 性 的 实 现 技 术 现 代 电 子技 1 1 S e r Q v 约束 的类 型包括 : 术 ,0 2 20 1主键 ( KM R E )约 束 。 . P IA YKY f 刘 晓恂 . L Sr r数 据库 系统 中数 据 完整 性 的控制 u_ 州教 2 1 S e e Q v 】 扬 通过在 表 中定义 一个 主键 标 识表 中的每 行记 录 ,但 是 每个表 育 学院 学报 , 0 2 7 0 『 汤娟 , 3 1 刘小梅 . 据库 应 用 系统 中数据 完整 性 的研 究卟 交通与 计 数 中只 能有一 个主键 ,并且 唯一 且不 能为 空。 2 唯一 ( N Q E . U I U )约束 。 算机 , 0 2 2 0 该 约束 主要 用来 限制 表 的非主键 列 中不 允许输 入重 复值 。在 『l 洪. e e . 系数据 库 系统 管理 与开发 指 南. 工 4杨正 s Sr r 0关 QL v 7 机械 个表 中 ,可 以设置 多个 唯一 约束 ,每 个唯 一约 束可 以定义 到一 业部 出版社 , 0 2 0 0 『Mi oo QLSr r . 5 c s ̄S ev 0数据 库 系统 管理 与应 用 开发 . 1 r e7 北京人 民 列上 ,也可 以定 义到 多列上 ,空值可 以出现在某 列 中一 次。 3 检查 ( H C )约束 。 . CE K 邮 电 出版社 , 9 1 9 9 通 过检 查输 入表 列 的数据 的值 来维 护值 域 的完整性 ,通 过对 【 薛华 成. 6 】 管理信 息 系统. 大学 出版社 , 9 清华 1 5 9
数据库实验报告 数据完整性

一、实验目的
法。
实验 6 数据完整性
1.掌握 Transact-SQL 语句(CREATE RULE、DROP RULE)创建和删除规则的方
2.掌握系统存储过程 sp_bindrule、sp_unbindrule 绑定和解除绑定规则的
操作方法,以及 sp_help、sp_helptext 查询规则信息、sp_rename 更名规则的
CREATE rule phone_rule AS @电话号码 LIKE '[0-9][0-9][0-9][0-9][0-9][0-9][0-9]'
检验: 电话号码为 8 位时无法插入!
电话号码为 7 位ห้องสมุดไป่ตู้可以插入!
南京师范大学中北学院
对全部高中资料试卷电气设备,在安装过程中以及安装结束后进行高中资料试卷调整试验;通电检查所有设备高中资料电试力卷保相护互装作置用调与试相技互术关,通系电1,力过根保管据护线生高0不产中仅工资2艺料22高试2可中卷以资配解料置决试技吊卷术顶要是层求指配,机置对组不电在规气进范设行高备继中进电资行保料空护试载高卷与中问带资题负料2荷试2,下卷而高总且中体可资配保料置障试时2卷,32调需3各控要类试在管验最路;大习对限题设度到备内位进来。行确在调保管整机路使组敷其高设在中过正资程常料1工试中况卷,下安要与全加过,强度并看工且25作尽52下可22都能护可地1关以缩于正小管常故路工障高作高中;中资对资料于料试继试卷电卷连保破接护坏管进范口行围处整,理核或高对者中定对资值某料,些试审异卷核常弯与高扁校中度对资固图料定纸试盒,卷位编工置写况.复进保杂行护设自层备动防与处腐装理跨置,接高尤地中其线资要弯料避曲试免半卷错径调误标试高方中等案资,,料要编试求5写、卷技重电保术要气护交设设装底备备置。4高调、动管中试电作线资高气,敷料中课并设3试资件且、技卷料中拒管术试试调绝路中验卷试动敷包方技作设含案术,技线以来术槽及避、系免管统不架启必等动要多方高项案中方;资式对料,整试为套卷解启突决动然高过停中程机语中。文高因电中此气资,课料电件试力中卷高管电中壁气资薄设料、备试接进卷口行保不调护严试装等工置问作调题并试,且技合进术理行,利过要用关求管运电线行力敷高保设中护技资装术料置。试做线卷到缆技准敷术确设指灵原导活则。。:对对在于于分调差线试动盒过保处程护,中装当高置不中高同资中电料资压试料回卷试路技卷交术调叉问试时题技,,术应作是采为指用调发金试电属人机隔员一板,变进需压行要器隔在组开事在处前发理掌生;握内同图部一纸故线资障槽料时内、,设需强备要电制进回造行路厂外须家部同出电时具源切高高断中中习资资题料料电试试源卷卷,试切线验除缆报从敷告而设与采完相用毕关高,技中要术资进资料行料试检,卷查并主和且要检了保测解护处现装理场置。设。备高中资料试卷布置情况与有关高中资料试卷电气系统接线等情况,然后根据规范与规程规定,制定设备调试高中资料试卷方案。
第五章 数据库完整性

例2:将SC表中的SNO、cno属性组定义为码 create table sc (sno char(9) not null, cno char(4) not null, grade smallint, primary key(sno,cno) )
8
5.1.2 实体完整性的违约处理
对于实体完整性的检查,包括:
在子表中修改外码(也是主属性)的策略
6. 在参照关系(子表)中修改外码(同时是主码 属性 )。与在参照关系中插入元组类似,可以 有2种策略: 受限修改 递归修改 RDBMS在实现参照完整性时: 需要向用户提供定义主码、外码的机制。 向用户提供按照自己的应用要求选择处理依 赖关系中对应的元组的方法。
6
5.1 实体完整性
5.1.1 定义实体完整性 例1:将student表中的sno属性定义为码 create table student (sno char(9) primary key, sname char(20) not null, ssex char(2), sage smallint, sdept char(20) )
26
5.4 完整性约束命名子句
1. 完整性约束命名子句 Constraint <完整性约束条件名><完整性约 束条件> 例5.10 建立学生登记表 student,要求学号在 90000—99999 之间,姓名不能取空值,年 龄小于30,性别只能是“男”或者“女”
5
数据库完整性控制机制
DBMS完整性控制机制: 1. 提供定义完整性约束条件的机制:提供定义数 据完整性约束条件的方法,完整性约束条件作为 模式的一部分存入数据库中; 2. 提供完整性检查的方法:进行完整性检查,检 查数据是否满足约束条件; 3. 进行违约处理:若有违反,采取相应措施(拒 绝、报告、改正)处理。 完整性子系统:DBMS中执行完整性控制的子系统。 其功能为监督事务的执行,测试其是否违反完整性 约束条件;若有违反,则分情况进行预定的处理。
组织机构代码数据库数据完整性和安全机制概述

改; 再例 如 修改列 值 时有 时需 要ห้องสมุดไป่ตู้ 照 l 旧值 , 且新 其 并 旧值 之 间需要 满 足某 种约 束条 件 ,如经 济类 型 原来
录入 的是 小类 不能 改 为 巾类 或大类 。
2 代 码 数 据 的 安 全 性
代码 数据 完 整性 是指 代码 数据 库数 据 的正 确性 与相 容性 数据 库 完整性 是 判别数 据 库数据 质 量好 坏 的一个 主要标 准 。 了维护 数据库 的 完整性 , 为 代码 数据 库 管理 系统 提供 了一 组 检查数 据 库 中数 据 是否 满足 语 义约 束规 定 的条件 ,包 括检 查 数据 关 系模 型 的完整 性 约束 条件 ,以及利 用存储 过 程触 发器 等将 完 整性 约束 条件 变成 实 现检 查 ,数据 完 整性 约束具 备 如下 特征 : ( ) 据 的值 正 确 无 误 , 1数 即数 据 类 型正 确 , 数据 的值 规定 的范 围之 内 ] ( )数 据 的存储 符 合表 格数 据之 间 及不 同表 格 2 数 据之 间 的 自洽关 系 。 () 3 数据 完整 性约 束 , 即静态 约束 和动态 约束 。 静 态 约束是 指 数据 库在 稳定 状态 时数 据对 象 应 满 足 的约 束 条件 括 静态 列 级 约束 、 态元 组 ( 包 静 记 录) 约束 、 态关 系约 束 以及空值 约束 。 静 静态 元组 ( 记 录) 约束 就是 规定 数据记 录 之间各 个列 值 的关系 。 例 如 机构类 型 、 注册 资 金 , 法人 姓名 、 注册 号 、 身份 证 号 码( 护照 号码 ) ; 等 如果机 构类 型是 企业 法 人 , 册 资 注 金 就不 能为空 , 册号 和法 人姓 也不 能为 空 静态 注 关系约 束是 指在 一 个 关系 的各 个元组 ( 记录 ) 间或 之 者若干 关 系之 问存 存 的约束 .一 般有 实体 完 整性 约 束, 应用 完 整性 约 束 , 函数依 赖 约束 和统 计约束 ,统 汁约束 指 字段值 与 关 系 中多个元 组 的统 计之 问 的约
实验四 数据的完整性安全性

徐龙琴、刘双印设计制作实验四数据完整性安全性数据的完整性、安全性实验四实验目的一、掌握数据安全性和完整性的概念,以及如何保证数据库中数据安全及完整性。
1.SQL Server中有关用户、角色及操作权限的管理方法.掌握2.学会创建和使用规则、缺省。
3.二、实验内容1 数据库的安全性实验,通过SSMS设置SQL Server的安全认证模式.实现对SQL Server的用户和角色管理,设置和管理数据操作权限.2数据库的完整性实验。
使用Transact-SQL设计规则、缺省、约束和触发器。
三、实验要求.数据的完整性实⑴用SQL语句创建一学生成绩数据库(XSCJ),包括学生(XSQK)、课程(KC)和成绩表(XS_KC):学生情况表(XSQK)列名数据类型长度是否允许为空值N 6 Char 学号N 8 Char 姓名N 性别 Bit1smalldatetime 出生日期 2Char 10 专业名Char 10 所在系Y11char联系电话create database xscjuse xscjcreate table xsqk(学号char(6)not null,姓名char(8)not null,性别bit not null,出生日期smalldatetime,专业名char(10),所在系char( 10),null))11(char联系电话徐龙琴、刘双印设计制作实验四数据完整性安全性课程表(KC)列名数据类型长度是否允许为空值N Char 课程号 3N Char 课程名 2010 Char 教师开课学期 1 TinyintTinyint 1 学时NTinyint学分 1create table kc(课程号char(3)not null,课程cha2nonull,教师char(10),开课学期tinyint,学时tinyint,学分tinyint not null)成绩表(XS_KC)数据类型长度是否允许为空值列名Char N 学号 6Char 课程号N 3Smallint成绩2create table xs_kc(学号char(6)not null, 课程号char(3)not null,)smallint成绩实验四数据完整性安全性徐龙琴、刘双印设计制作⑵数据的实体完整性实验①用SSMS分别将学生情况表(XSQK)的学号字段、课程表(KC)的课程号字段设置为主健②用T-SQL语句将成绩表(XS_KC)的学号、课程号字段设置为主健alter table xs_kcadd primary key(学号,课程号)实验四数据完整性安全性徐龙琴、刘双印设计制作⑶数据的参照完整性实验①用SSMS为成绩表(XS_KC)创建外键FK_ XSQK_ID,外键FK_ XSQK_ID参照学生情况表(XSQK)表的学号②用T-SQL语句成绩表(XS_KC)创建外键FK_ KC_ID,外键FK_ KC _ID参照课程表(KC)表的课程号alter table xs_kcadd constraint FK_KC_ID foreign key (课程号)references kc(课)程号.实验四数据完整性安全性徐龙琴、刘双印设计制作⑷数据的用户定义完整性实验①用T-SQL语句为学生情况表(XSQK)的姓名列创建一个唯一约束alter table xsqkadd constraint ch_xsqk_unique unique(姓名))的性别列创建一个检查约束,使得性别的值为男或女XSQK为学生情况表(SSMS②用.实验四数据完整性安全性徐龙琴、刘双印设计制作③用T-SQL语句为成绩表(XS_KC)的成绩列创建一个检查约束,使得成绩的值在(0~100)之间alter table xs_kcadd constraint ch_grade check(成绩between 0 and 100)60)的学时列创建一个缺省约束,缺省值为KC语句课程表(SSMS④用.实验四数据完整性安全性徐龙琴、刘双印设计制作⑤用T-SQL语句课程表(KC)的学分列创建一个缺省约束,缺省值为2alter table kcadd constraint default_kc_credit default 2 for学分的格式,并分别将其导入数据库的各个表中:Excel2.将如下数据分别转换成文本数据或.徐龙琴、刘双印设计制作数据完整性安全性实验四):学生情况表(XSQK学号姓名性别出生日期专业所在系联系电话88297147 020101 杨颖 1980-7-20 0 计算机应用计算机88297147 计算机计算机应用 1981-1-15 020102 方露露088297151 1980-2-20 俞奇军 1 信息管理020103 计算机 88297151 胡国强1 1980-11-7 020104 计算机信息管理88297152 020105 1980-7-29 薛冰1 水利工程水利系 88297161 电子商务经济系1981-3-10 020201 0 秦盈飞88297062 电子商务经济系 1980-9-25 0 020202 董含静88297171 电子商务经济系1980-8-7 1 020203 陈伟 88297171房建1980-7-20020204陈新江1水利系实验四数据完整性安全性徐龙琴、刘双印设计制作实验四数据完整性安全性徐龙琴、刘双印设计制作:)KC课程表(.徐龙琴、刘双印设计制作实验四数据完整性安全性课程号课程名教师开课学期学时学分3 计算机原理2 45 101 陈红3 3 102 王颐计算方法 454 60 2 103 操作系统徐格5 3 数据库原理及应用应对刚104 753 网络基础吴江江4 105 456 高等数学孙中文 1 90 1066 英语陈刚107 1 90 5VB赵红韦3108程序设计 70实验四数据完整性安全性徐龙琴、刘双印设计制作实验四数据完整性安全性徐龙琴、刘双印设计制作:)XS_KC成绩表(.徐龙琴、刘双印设计制作数据完整性安全性实验四学号课程号成绩85 020101 10187 020101 102 88 107 020101 58 101 02010263 020102 10276 020104 10755 020202 103 80 108 020202 57 103 02020371020204103实验四数据完整性安全性徐龙琴、刘双印设计制作3. 理解默认值的概念和作用①用语句创建名为Xi_default,值为“计算机系”的默认值create default Xi_default as'计算机系'实验四数据完整性安全性徐龙琴、刘双印设计制作②将默认值Xi_default绑定到学生表中的所在系的属性列上sp_bindefault Xi_default,'xsqk.所在系'③解除学生表所在系的属性列上的默认值sp_unbindefault'xsqk.所在系'④删除默认值Xi_defaultdrop default Xi_default注:创建默认值的格式: create default 默认值名 as ‘默认值'默认值绑定的格式:sp_bindefault 默认值名, <'表名.列名'︱自定义数据类型名称>解除默认值绑定格式:sp_unbindefault <'表名.列名'︱自定义数据类型名称>删除默认值格式:Drop default 默认值名4.理解规则的概念和作用①用语句创建规则“rule_kkxq”,用以限制插入该规则所绑定的列中的值只能取1、2、3、4、5、6create rule rule_kkxq as@ss in(1,2,3,4,5,6)②将“rule_ kkxq”规则绑定到课程表的开课学期属性上,并执行以下语句,看看能否正常执行,为什么:Insert into 课程表Values(109,'C语言','李方',8,64,4)sp_bindrule rule_kkxq,'kc.开课学期'不能正常执行因为数值8不在规则rule_kkxq所绑定的数据范围内③若不解除规则,能否将规则rule_ kkxq直接删除?不能,需先解除规则才能删除规则rule_ kkxq :sp_unbindrule'kc.开课学期'drop rule rule_kkxq注:创建规则的格式: create rule 规则名 as @列名约束条件规则绑定的格式: sp_bindrule 规则名, <'表名.列名'︱自定义数据类型名称>解除规则绑定格式:sp_unbindrule <'表名.列名'︱自定义数据类型名称>删除规则格式:Drop rule 规则名5.数据的安全性实验:(1)设置身份验证模式①写出查看当前SQL Server身份验证模式的过程,即查看当前SQL Server系统到底是采用Windows身份验证还是混合身份验证模式。
如何在数据库管理中实现数据完整性

如何在数据库管理中实现数据完整性在当今数字化的时代,数据已经成为企业和组织的重要资产。
而数据库管理中的数据完整性,就像是守护这些资产的坚固堡垒,确保数据的准确性、一致性和可靠性。
那么,如何在数据库管理中实现数据完整性呢?这是一个值得深入探讨的重要问题。
首先,我们需要明确什么是数据完整性。
简单来说,数据完整性指的是数据的准确性和一致性,即在数据库中存储的数据应该是正确的、完整的,并且符合预期的规则和约束。
如果数据完整性得不到保障,可能会导致错误的决策、业务流程的中断,甚至给企业带来严重的经济损失。
为了实现数据完整性,我们可以从以下几个方面入手。
一、设计合理的数据库结构在数据库设计阶段,就要充分考虑数据完整性的需求。
合理的数据库结构是实现数据完整性的基础。
这包括选择合适的数据类型、定义主键和外键、建立索引等。
选择合适的数据类型可以确保数据的存储和处理的准确性。
例如,对于整数类型的数据,应该选择适当的整数类型(如 smallint、int 或bigint),以避免数据溢出或精度损失。
定义主键可以唯一标识每一条记录,确保数据的唯一性。
外键则用于建立表与表之间的关联,保证数据的一致性。
通过定义外键约束,可以防止在相关表中插入或更新不存在的关联数据。
建立索引可以提高数据的查询和检索效率,但也要注意不要过度索引,以免影响数据的插入和更新性能。
二、制定并实施数据规则和约束在数据库中,可以通过定义各种规则和约束来保证数据的完整性。
常见的约束包括主键约束、唯一约束、非空约束、检查约束和默认值约束等。
主键约束确保表中的每一行都有唯一的标识符,避免重复数据的出现。
唯一约束则保证某一列的值在整个表中是唯一的。
非空约束要求某些列必须有值,不能为 NULL。
这可以确保关键信息不会缺失。
检查约束可以用于定义更复杂的条件,例如限制某个列的值在特定的范围内,或者满足特定的格式要求。
默认值约束为没有提供值的列提供默认的取值,保证数据的完整性。
数据库设计——完整性(quan)

约束3:检查约束
作用:通过一个或多个字段上的输入值 是否符合设定的检查条件来保证数据库 数据的完整性。 一个表中可以定义多个检查约束; 每个CREATE TABLE语句中每个字段只 能定义一个检查约束; 当执行INSERT语句或者UPDATE语句时, 检查约束将验证数据;
数据库完整性
为维护数据库的完整性,DBMS必须:
1.提供定义完整性约束条件的机制 2.提供完整性检查的方法 3.违约处理
关系数据库的数据完整性
数据完整性就是指存储在数据库中的 数据的一致性和准确性。 在关系数据库中,主要有以下三种 类型: 行完整性 列完整性 参照完整性
• • •
关系数据库的数据完整性
create table customers ( CustomerID int identity(1,1) primary key, FirstName varchar(20) not null, LastName varchar(20) not null, Address varchar(100), City varchar(20), Tel varchar(20) UNIQUE, Company varchar(50), Birthday datetime, Type tinyint default 1 )
实现完整性的方法之一 —— 约束
使用CREATE TABLE语句(ALTER TABLE语 句)表示在创建(或修改)表的时候定义约束。 定义约束时,既可以把约束放在一个列上,也 可以把约束放在多个列上。如果把约束放在一 个列上,那么该约束称为列级约束;如果把约 束放在多个列上,那么把该约束称为表级约束。
Customers
字段号 1 2 3 4 5 6 7 8 字段名 客户ID 客户姓名 地址 城市 电话 公司 客户类型 出生日期 数据类型 整型 变长字符串 变长字符串 变长字符串 变长字符串 变长字符串 Tinyint 日期/时间 约束说明 标识列,主键 非空
数据库 默认值约束、默认值对象、检查约束、规则、完整性实现

Principle and Application of Database System
cno 3-105 6-166 3-105 3-245 3-105 3-245 3-105 6-166 3-105 6-166 3-105 3-245
degree 64 85 92 86 88 75 91 79 78 81 76 68
数据库原理与应用
Principle and Application of Database system 安庆师范学院计算机与信息学院
AnQing Teachers College Department of Computer & Information
Principle and Application of Database System
13.1 在表中定义及删除默认值约束
1. 默认值约束的定义
1) 定义表结构时定义字段的默认值约束 语法格式: CREATE TABLE table_name ( /*指定表名*/
column_name datatype NOT NULL | NULL [DEFAULT constraint_expression] [,…n] /*默认值约束表达式*/
) /*定义列名、该列的数据类型、是否空值及默认值约束*/
Principle and Application of Database System
例1 对于student数据库,定义studentx表时 定义ssex字段的默认值约束为男。
CREATE TABLE studentx
(sno char(5) PRIMARY KEY, sname char(8), ssex char(2) DEFAULT '男', sbirthday datetime,
数据库的完整性约束-包含答案

数据库的完整性约束-包含答案实验八:数据库的完整性约束一、实验目的1.掌握主键约束、外键约束及及check约束的用法;2.掌握默认值约束的应用。
二、实验环境已安装SQL Server 2008 企业版的计算机;具有局域网环境,有固定IP;三、实验学时2学时四、实验要求1.熟悉数据库完整性相关概念及约束;2.了解约束、默认值;3.完成实验报告;五、实验准备知识1、创建primary key约束(1)在创建数据表时创建primary key约束CREATE TABLE table_name(column_name data_type [PRIMARY KEY | unique | NOT NULL] [, column_name data_type [PRIMARY KEY | unique | NOT NULL]...[PRIMARY KEY(column [,...n])])(2)在修改表时同时创建primary key约束ALTER TABLE table_nameADD primary key(column [,...n])2、创建Foreign key约束(1)创建表时同时定义Foreign key约束CREATE TABLE table_name(column_name data_type [FOREIGN KEY] REFERNCES ref_table(ref_column)[, column_name data_type [FOREIGN KEY] REFERNCES ref_table(ref_column)...[FOREIGN KEY] (column) REFERNCES ref_table(ref_column) )(2)通过修改表定义Foreign key约束ALTER TABLE table_nameADD [FOREIGN KEY] (column)REFERNCES ref_table(ref_column )3、创建check约束(1)创建数据表时创建check约束CREATE TABLE table_name(column_name data_type [NOT NULL | CHECK (logical_expression)] ...CHECK (logical_expression)])(2)在修改数据表时添加check约束ALTER TABLE table_nameADD CHECK (logical_expression)4、创建default约束(1)创建数据表时创建default约束Create table table_name( column_name datatype [not null | DEFAULT (constraint_expression)] …)(2)修改数据表时添加一个字段的同时创建default约束Alter table table_nameADD column_name datatype [not null |DEFAULT (constraint_expression)] with values(3)对表中指定的列定义默认值约束Alter table table_nameADD [ DEFAULT (constraint_expression)] For column5、完整性约束命名子句CONSTRAINT <完整性约束条件名>[PRIMARY KEY 短语︱FOREIGN KEY 短语︱CHECK 短语]6、删除primary key约束或unique约束ALTER TABLE table_nameDROP CONSTRAINT constraint_name [, ...n]六、实验内容及步骤使用T-SQL语句实现以下操作;1.请用至少2种方法定义stu数据库中student表的主键sno;方法1:CREATE TABLE Student(Sno CHAR(9) PRIMARY KEY,Sname CHAR(20),Ssex CHAR(2),Sage SMALLINT,Sdept CHAR(20))方法2:CREATE TABLE Student(Sno CHAR(9),Sname CHAR(20),Ssex CHAR(2),Sage SMALLINT,Sdept CHAR(20),PRIMARY KEY(Sno))2.将数据库stu的表course的cno字段定义为主键,约束名称为cno_pk;Alter table courseAdd constraint cno_pk primary key (cno)3.为表course中的字段cname添加唯一值约束;Alter table courseAdd constraint cname_pk unique (cname)4.将数据库stu的表sc的sno及cno字段组合定义为主键,约束名称为sc_pk;Alter table scAdd constraint sc_pk primary key (sno,cno)5.对于数据表sc的sno、cno字段定义为外码,使之与表student 的主码sno及表course的主码cno对应,实现如下参照完整性:1)删除student表中记录的同时删除sc表中与该记录sno字段值相同的记录;2)修改student表某记录的sno时,若sc表中与该字段值对应的有若干条记录,则拒绝修改;3)修改course表cno字段值时,该字段在sc表中的对应值也应修改;4)删除course表一条记录时,若该字段在在sc表中存在,则删除该字段对应的记录;Use stuCreate table student(Sno CHAR(9),Sname CHAR(20),Ssex CHAR(2),Sage SMALLINT,Sdept CHAR(20),PRIMARY KEY(Sno))Create table course(cno char(4),cname char(40),cpno char(4),ccedit smallint,foreign key (cpno) references course(cno),primary key (cno))Create table sc(sno char(9),cno char(4),Grade smallint,foreign key (sno) references student(sno)on delete cascade on update no action,foreign key (cno) references course (cno)on delete cascade on update cascade)6.定义check约束,要求学生学号sno必须为9位数字字符,且不能以0开头,第二三位皆为0;Alter table studentAdd CONSTRAINT sno_ckCheck (sno like ‘[1-9]00 [0-9] [0-9] [0-9] [0-9] [0-9] [0-9]’)7.定义stu数据库中student表中学生年龄值在16-25范围内;CREATE TABLE Student(Sno CHAR(9) PRIMARY KEY,Sname CHAR(20),Ssex CHAR(2),Sage SMALLINT Check (sage>=16 and sage<=25),Sdept CHAR(20))8.定义stu数据库中student表中学生性别列中只能输入“男”或“女”;CREATE TABLE Student(Sno CHAR(9) PRIMARY KEY,Sname CHAR(20),Ssex CHAR(2) Check(Ssex in (‘男’,’女’)),Sage SMALLINT,Sdept CHAR(20))9.定义stu数据库student表中学生年龄值默认值为20;CREATE TABLE Student(Sno CHAR(9) PRIMARY KEY,Sname CHAR(20),Ssex CHAR(2),Sage SMALLINT Default 20,Sdept CHAR(20))七、出现问题及解决办法如:某些操作无法执行,如何解决?。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
--②CREDIT取值为至以内的数字;
--? 参照完整性:TNO为外码,并实现级联更新和级联删除操作;
CREATETABLECourse
(CNOCHAR(4),
TNOCHAR(3),
CNAMECHAR(20)NOTNULL,
CREDITINTcheck(CREDIT>=1andCREDIT<=10),
--1、Dept表
--DEPTNO CHAR()
--E VARCHAR()DNAM
--实体完整性:DEPTNO为主码;
--用户定义完整性
--①DEPTNO的取值为至;
--②DNAME取值非空且唯一;
CREATETABLEDEPT
(DEPTNOCHAR(2)PRIMARYKEY
constraintc1check(DEPTNObetween01and99),
PRIMARYKEY(SNO,CNO),
FOREIGNKEY(SNO)REFERENCESStudent(SNO)
ondeletecascade
onupdatecascade,
FOREIGNKEY(CNO)REFERENCESCourse(CNO)
ondeletenoaction
onupdatenoaction,
DNAMEVARCHAR(20)
constraintc2NOTNULLunique,
);
--2、Student表
--? SNO CHAR()
--? SNAME VARCHAR()
--? SEX CHAR()
--? DEPTNO CHAR()
--
--? 实体完整性:SNO为主码;
--? 参照完整性:DEPTNO为外码,并实现级联更新和级联删除操作;
--? 用户定义完整性
--①SNO取值为级的学号取值范围,如等。
--②SNAME 取值非空;
--③SEX的取值只能为男或女;
CREATETABLEStudent
(SNOCHAR(10)PRIMARYKEY
constraintb1check(SNObetween00and99),
SnamevarCHAR(8)NOTNULLunique,
PRIMARYKEY(CNO),
FOREIGNKEY(TNO)REFERENCESTeacher(TNO)
ondeletecascade
onupdatecascade,
);
droptableCourse
--5、SC表
--? SNO CHAR()
--? CNO CHAR()
--? GRADE SMALLINT
--? TNO CHAR()
--? TNAME VARCHAR()
--? DEPTNO CHAR()
--
--? 实体完整性:TNO为主码;
--? 参照完整性:DEPTNO为外码,并实现级联更新和级联删除操作;
--? 用户定义完整性
--①TNO取值为开头的四位数字字符串;
--②TNAME取值非空;
CREATETABLETeacher
--()创建触发器Trig2,实现在SC表里删除一条数据时,Student表里对应的学生的CNT值自动减。
CREATETRIGGERTRIG2ONSC
FORDELETE
AS
updatestudent
SETCNT=CNT-1
WHEREIN
(SELECTFROMDELETED)
--()创建触发器Trig3,实现不允许修改SC表的Sno和Cno。
--在Student表上创建以下触发器。
--()创建触发器Trig1,实现在SC表里添加一条数据时,Student表里对应的学生的CNT值自动增加。
CREATETRIGGERTRIG1ONSC
FORINSERT
AS
UPDATESTUDENT
SETCNT=CNT+1
WHEREIN
(SELECTSNOFROMINSERTED)
(TNOCHAR(3)PRIMARYKEY
constrainta1check(TNObetween0800and0899),
TNAMEvarCHAR(8)NOTNULL,
DEPTNOCHAR(2),
FOREIGNKEY(DEPTNO)REFERENCESDEPT(DEPTNO)
ondeletecascade
--
--? 实体完整性:(SNO,CNO)为主码;
--? 参照完整性:SNO外码、CNO外码,都实现级联删除和级联更新操作;
--? 用户定义完整性
-- GRADE取值在到之间。
CREATETABLESC
(SNOCHAR(10),
CNOCHAR(4),
GRADESMALLINTcheck(GRADE>=0andGRADE<=100),
SsexCHAR(2)
constraintb2check(Ssexin('男','女')),
DEPTNOΒιβλιοθήκη HAR(2),FOREIGNKEY(DEPTNO)REFERENCESDEPT(DEPTNO)
ondeletecascade
onupdatecascade
);
droptableStudent
--3、Teacher表
onupdatecascade
);
droptableTeacher
--4、Course表
--? CNO CHAR()
--? TNO CHAR()
--? CNAME VARCHAR()
--? CREDIT SNALLINT
--
--? 实体完整性:CNO;
--? 用户定义完整性
--①CNAME取值非空;
4实验报告
《数据库原理》实验报告
实验题目:数据完整性
姓名
吴位吕
日期
2012-5-22
实验环境:XP Windows系统环境
Microsoft SQL Server 2005中?SQL Server Management Studio
实验内容与完成情况:
一、三类完整性的实现
对系表Dept、学生表Student、教师表Teacher、课程表Course、SC表,教师授课表TC,实现规定的完整性,并验证,当操作违反了完整性约束条件时,DBMS如何处理。
);
--二、触发器的实现
--1、修改Student表,增加属性CNT,SMALLINT型,表示学生的选课门数,设置CNT的默认值为。
--增加属性SZK,SMALLINT型,表示素质选修课学分。
ALTERTABLEStudentADDCNTSMALLINT;
ALTERTABLEStudentADDSZKSMALLINT;