数据库完整性代码
- 格式:doc
- 大小:54.00 KB
- 文档页数:5
数据库的安全性、完好性、并发控制和恢复为了保证数据库数据的安全靠谱性和正确有效, DBMS 一定供给一致的数据保护功能。
数据保护也为数据控制,主要包含数据库的安全性、完好性、并发控制和恢复。
数据库的安全性数据库的安全性是指保护数据库以防备不合法的使用所造成的数据泄漏、改正或损坏。
计算机系统都有这个问题,在数据库系统中大批数据集中寄存,为很多用户共享,使安全问题更加突出。
在一般的计算机系统中,安全举措是一级一级设置的。
在 DB 储存这一级可采纳密码技术,当物理储存设施失窃后,它起到保密作用。
在数据库系统这一级中供给两种控制:用户表记和判定,数据存取控制。
在 ORACLE 多用户数据库系统中,安全体制作以下工作:防备非受权的数据库存取;防备非受权的对模式对象的存取;控制磁盘使用;控制系统资源使用;审计用户动作。
数据库安全可分为二类:系统安全性和数据安全性。
系统安全性是指在系统级控制数据库的存取和使用的体制,包含:有效的用户名 /口令的组合;一个用户能否受权可连结数据库;用户对象可用的磁盘空间的数目;用户的资源限制;数据库审计是不是有效的;用户可履行哪些系统操作。
数据安全性是指在对象级控制数据库的存取和使用的体制,包含:哪些用户可存取一指定的模式对象及在对象上同意作哪些操作种类。
在 ORACLE 服务器上供给了一种随意存取控制,是一种鉴于特权限制信息存取的方法。
用户要存取一对象一定有相应的特权授给该用户。
已受权的用户可随意地可将它受权给其余用户,因为这个原由,这类安全性种类叫做随意型。
ORACLE 利用以下体制管理数据库安全性:数据库用户和模式;特权;角色;储存设置和空间份额;资源限制;审计。
数据库的存取控制ORACLE保护信息的方法采纳随意存取控制来控制所有用户对命名对象的存取。
用户对对象的存取受特权控制。
一种特权是存取一命名对象的同意,为一种规定格式。
ORACLE 使用多种不一样的体制管理数据库安全性,此中有两种体制:模式和用户。
第二章数据库的完整性控制数据完整性(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.思考:⑴如果同学们在填学生表的时候将自己的班级名称写错了, 写成了一个学校中根本不存在的班级, 这样的结果肯定是错误的。
一、检查数据库完整性的重要性在数据库管理中,数据库的完整性是非常重要的。
如果数据库损坏或不完整,可能会导致数据丢失或系统崩溃。
定期检查数据库的完整性是保证数据安全和系统稳定性的关键步骤。
二、检查数据库完整性的方法1. 使用DBCC CHECKDB命令DBCC CHECKDB是SQL Server提供的一个用于检查数据库完整性的命令。
它可以检查数据库中所有对象的完整性,包括表、索引、视图等。
可以通过以下语句来运行DBCC CHECKDB命令:DBCC CHECKDB ('database_name');2. 使用DBCC CHECKTABLE命令DBCC CHECKTABLE命令可以用来检查数据库中特定表的完整性。
可以通过以下语句来运行DBCC CHECKTABLE命令:DBCC CHECKTABLE ('table_name');3. 使用DBCC CHECKFILEGROUP命令DBCC CHECKFILEGROUP命令可以用来检查文件组的完整性。
可以通过以下语句来运行DBCC CHECKFILEGROUP命令:DBCC CHECKFILEGROUP ('filegroup_name');4. 使用DBCC CHECKALLOC命令DBCC CHECKALLOC命令可以用来检查分配给数据库对象的存储空间的完整性。
可以通过以下语句来运行DBCC CHECKALLOC命令:DBCC CHECKALLOC;三、检查数据库完整性的注意事项1. 在进行完整性检查之前,应该备份数据库以防止任何意外发生。
2. 在生产环境中进行完整性检查时,应该避免对数据库进行写操作,以免影响正在运行的业务。
3. 对于大型数据库,完整性检查可能需要较长的时间,应该安排在系统负载较低的时段进行。
四、检查数据库完整性的建议1. 定期检查数据库完整性,例如每周或每月进行一次完整性检查。
DBMS基本操作DBMS(Database Management System)是指数据库管理系统,用于管理和操作大规模的数据库。
DBMS提供了一些基本的操作来创建,查询,更新和删除数据,以及维护数据库的完整性和安全性。
DBMS的基本操作包括以下几个主要方面:1.数据定义语言(DDL)操作:-创建数据库:使用CREATEDATABASE语句来创建一个新的数据库。
-创建表:使用CREATETABLE语句来定义一个新的表,包括表名、列名、数据类型和约束条件。
-修改表结构:使用ALTERTABLE语句来添加、修改或删除表的列、索引、约束等。
-删除表:使用DROPTABLE语句来删除一个已存在的表。
2.数据操作语言(DML)操作:-插入数据:使用INSERT语句将新的数据行插入到表中。
-查询数据:使用SELECT语句来从表中检索数据,可以通过WHERE子句来指定条件。
-更新数据:使用UPDATE语句来更新表中已存在的数据行。
-删除数据:使用DELETE语句来删除表中的数据行,也可以通过WHERE子句来指定条件。
3.事务管理操作:-开始事务:使用BEGINTRANSACTION语句来开始一个新的事务。
-提交事务:使用COMMIT语句来提交一个事务,将对数据库的修改永久保存。
-回滚事务:使用ROLLBACK语句来回滚一个事务,撤销对数据库的修改。
-设置保存点:使用SAVEPOINT语句来设置一个保存点,以便在事务中可以回滚到该点。
4.数据库完整性约束:-主键约束:用于唯一标识表中的每一条记录。
-外键约束:用于建立表之间的关联关系。
-唯一约束:用于确保其中一列的值在表中唯一-非空约束:用于确保其中一列的值不能为空。
-默认值约束:用于在插入数据时为其中一列指定默认值。
5.数据库安全性操作:-用户管理:使用CREATEUSER语句来创建一个新的用户,以及GRANT 和REVOKE语句来授予或撤销用户对数据库的访问权限。
2022年哈尔滨理工大学网络工程专业《数据库原理》科目期末试卷B(有答案)一、填空题1、使某个事务永远处于等待状态,得不到执行的现象称为______。
有两个或两个以上的事务处于等待状态,每个事务都在等待其中另一个事务解除封锁,它才能继续下去,结果任何一个事务都无法执行,这种现象称为______。
2、在关系数据库的规范化理论中,在执行“分解”时,必须遵守规范化原则:保持原有的依赖关系和______。
3、视图是一个虚表,它是从______导出的表。
在数据库中,只存放视图的______,不存放视图对应的______。
4、某事务从账户A转出资金并向账户B转入资金,此操作要么全做,要么全不做,为了保证该操作的完整,需要利用到事务性质中的_____性。
5、在设计局部E-R图时,由于各个子系统分别有不同的应用,而且往往是由不同的设计人员设计,所以各个局部E-R图之间难免有不一致的地方,称为冲突。
这些冲突主要有______、______和______3类。
6、完整性约束条件作用的对象有属性、______和______三种。
7、设在SQL Server 2000环境下,对“销售数据库”进行的备份操作序列如下图所示。
①出现故障后,为尽可能减少数据丢失,需要利用备份数据进行恢复。
首先应该进行的恢复操作是恢复_____,第二个应该进行的恢复操作是恢复_____。
②假设这些备份操作均是在BK设备上完成的,并且该备份设备只用于这些备份操作,请补全下述恢复数据库完全备份的语句RESTORE_____FROM BKWITH FILE=1,_____;8、数据管理技术经历了______________、______________和______________3个阶段。
9、关系规范化的目的是______。
10、某在SQL Server 2000数据库中有两张表:商品表(商品号,商品名,商品类别,成本价)和销售表(商品号,销售时间,销售数量,销售单价)。
信息工程学院实验报告课程名称:《数据库原理》实验项目名称:数据库的完整性和安全性一、实 验 目 的:(1)掌握数据库约束的概念;(2)熟悉SQL SERVER 的完整性约束技术。
(3)了解SQL SERVER 的违反完整性处理措施。
(4)了解登录账户的管理理念与具体方法。
(5)了解数据库用户的管理的要则。
(6)了解用户权限管理的内涵与方法。
二、实 验 设 备 与 器 件 Win7 +Sql server 2008 三、实 验 内 容 与 步 骤(一)测试完整性运行附录中的SQL 语句,理解SQL 语句中包含的完整性定义。
然后执行下面的SQL 语句,看是否能正常运行,若无法执行,请说明原因。
1.对dept 表进行数据增删改,并检查完整性规则 Dept 已存在的完整性规则如下: dno CHAR(2)PRIMARY KEYdnameV ARCHAR(20) NOT NULL,UNIQUE(1)增加数据INSERT INTO dept V ALUES('D1','计科系');----正常插入INSERT INTO dept V ALUES('D2','电信系');----正常插入INSERT INTO dept V ALUES(NULL,'机械系'); ----违反dno 主键(NOT NULL )规则INSERT INTO dept V ALUES('D2','机械系'); ----违反dno 主键(UNIQUE )INSERT INTO dept V ALUES('D3',NULL); ----违反dname 的NOT NULL 规则INSERT INTO dept V ALUES('D3','计科系'); ----违反dname 的UNIQUE 规则INSERT INTO dept V ALUES('D3','机械系');----正常插入(2)删除数据DELETE FROM dept WHERE dno='D3';----正常删除(3)修改数据UPDA TE dept SET dname='计算机科学系' WHERE dno='D1';----正常修改UPDA TE dept SET dname='电信系' WHERE dno='D1'; ----违反dname的UNIQUE规则UPDA TE dept SET dname=NULL WHERE dno='D1'; 违反dname的UNIQUE规则2.对student表进行数据增删改,并检查完整性规则Student已存在完整性规则如下:sno CHAR(2) PRIMARY KEYsname V ARCHAR(20) NOT NULL,ssex CHAR(2) NOT NULL, CHECK(ssex in('男','女'))sage INT NOT NULL,dno CHAR(2) NOT NULL, FOREIGN KEY REFERENCES dept(dno)ON DELETE CASCADE ON UPDATE CASCADE(1)增加数据INSERT INTO student V ALUES('S1','张刚','男',20,'D1');----正常插入INSERT INTO student V ALUES('S2','李梅','女',21,'D2');----正常插入INSERT INTO student V ALUES('S2','吴敏','男',20,'D1'); ----正常插入INSERT INTO student V ALUES(NULL,'吴敏','男',20,'D1'); ----违反sno 的主键(NOT NULL)规则INSERT INTO student V ALUES('S3','吴敏','男',NULL,'D1'); 违反sage 的主键(NOT NULL)规则INSERT INTO student V ALUES('S3','吴敏','M',20,'D1'); 违反ssex 的CHECK规则INSERT INTO student V ALUES('S3','吴敏','男',20,'D3'); ----正常插入INSERT INTO student V ALUES('S3','吴敏','男',20,'D1');----正常插入(2)删除数据DELETE FROM student WHERE sno='S3'; ----正常删除(3)修改数据UPDA TE student SET sname='赵强',dno='D2' WHERE sno='S1'-----正常修改UPDA TE student SET ssex='F' WHERE sno='S1'; -----违反ssex的CHECK 规则UPDA TE student SET sno='S2' WHERE sno='S1'; -----违反sno的主键(UNIQUE)规则UPDA TE student SET dno='D3' WHERE sno='S1'; 违反dno 的外键规则UPDA TE dept SET dno='D3' WHERE dno='D1';----检查dno的外键ON UPDATE规则,观察运行后效果DELETE FROM dept WHERE dno='D2';----检查dno的外键ON DELETE规则,观察运行后效果(二)使用规则实现数据完整性(1)在查询分析器中,利用命令(CREATE RULE),创建一个关于年龄(sage)约束的规则,将“sage”列的值约束在0~200之间;然后将所创建的规则绑定到“sage”列(提示:用命令Sp_bindrule)。
数据库的数据完整性与一致性检查案例说明书一、引言数据库是现代信息系统中的重要组成部分,为了保证数据库中数据的准确性和可靠性,数据完整性与一致性检查显得尤为重要。
本文通过案例说明,旨在介绍数据库的数据完整性与一致性检查的方法和步骤。
二、案例背景某电商平台的订单管理数据库中有一个名为“order”(订单)的表,其中包含订单号(order_id)、下单时间(order_time)、客户ID (customer_id)等字段。
由于业务增长迅速,该表的数据量已经达到了上百万条,而且不乏异常数据,例如订单号为空或重复,下单时间异常等情况。
为了保证订单数据的完整性和一致性,需要进行相应的检查和清理。
三、数据完整性检查数据完整性是指数据库中数据的正确性和完备性。
在订单管理数据库的案例中,可以通过以下方法进行数据完整性检查:1. 检查订单号的唯一性:通过查询数据库,统计订单号在表中的数量,如果存在订单号重复的情况,则说明数据存在问题,需进行清理。
2. 检查订单号的完整性:通过检查订单号是否为空或非法值,排除异常数据。
3. 检查下单时间的合法性:对下单时间进行范围检查,排除超过当前时间的异常数据。
四、数据一致性检查数据一致性是指数据的逻辑关系和业务规则在整个数据库中得到保持。
在本案例中,可以通过以下方法进行数据一致性检查:1. 检查客户ID的有效性:通过查询数据库,验证客户ID是否存在于客户信息表,排除无效客户ID的订单数据。
2. 检查订单时间与下单时间的关系:确保订单时间在下单时间之后,排除异常数据。
3. 检查订单状态的一致性:通过查询订单状态表,验证订单状态的合法性,排除异常订单状态的数据。
五、案例实施步骤为了保证数据库中订单数据的完整性和一致性,可以按照以下步骤进行案例实施:1. 数据备份:在进行任何数据检查和清理之前,先对数据库进行备份,以防止意外情况导致数据丢失。
2. 数据检查:按照上述的数据完整性和一致性检查方法,对订单表中的数据进行检查,记录异常数据和问题。
数据库的完整性约束-包含答案实验八:数据库的完整性约束一、实验目的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))七、出现问题及解决办法如:某些操作无法执行,如何解决?。
MySQL的备份验证与完整性校验方法MySQL是一种常用的开源关系型数据库管理系统,由于数据在企业中的重要性不言而喻,备份和完整性校验是MySQL数据库管理中必不可少的环节。
本文将介绍MySQL的备份验证与完整性校验方法,帮助读者更好地保护数据库数据的安全性。
一、备份验证方法1. 内容校验在备份MySQL数据库之前,首先需要采取措施验证备份的内容是否正确。
可以使用命令行工具mysqldump来进行备份,备份后使用gunzip命令进行解压,再使用mysqldump命令将备份文件导入到数据库中。
之后,使用SELECT语句从数据库中选择数据,并与原数据库做对比,确保数据的一致性。
2. 数字签名数字签名提供了一种验证备份文件完整性的方法。
在备份过程中,可以对备份文件进行数字签名,然后使用相应的公钥验证数字签名的有效性。
这样可以确保备份文件在传输过程中未被篡改。
3. 哈希校验为了验证备份文件的完整性,可以使用哈希算法对备份文件进行计算得到哈希值,并保存在备份文件的文件名或指定的文件中。
在数据需要恢复时,再次计算备份文件的哈希值,并与之前保存的哈希值进行对比,以验证备份文件的完整性。
二、完整性校验方法1. 校验和验证MySQL提供了校验和验证机制,通过对存储引擎的数据块进行检查和计算校验和值,以验证数据的完整性。
在创建表时可以指定校验和选项,MySQL会自动生成校验和值并与数据块进行比较,以检测数据块是否发生损坏。
2. 数据校验工具除了MySQL自带的校验和验证,还可以利用一些数据校验工具来验证MySQL数据库的完整性。
例如,可以使用pt-table-checksum工具对MySQL数据库中的表进行校验,以确保数据的一致性。
三、故障恢复方法除了备份验证与完整性校验,故障恢复也是MySQL数据库管理中的一个重要环节。
以下是一些常用的故障恢复方法:1. 冷备份恢复冷备份恢复指的是在数据库停止运行的情况下进行的数据恢复。
177
实验5
索引和数据完整性
目的与要求
(1)掌握索引的使用方法;
(2)掌握数据完整性的实现方法。
实验准备
(1)了解索引的作用与分类;
(2)掌握索引的创建方法;
(3)理解数据完整性的概念及分类;
(4)掌握各种数据完整性的实现方法。
实验内容
1.创建索引
(1)使用CREATE INDEX 语句创建索引
① 对YGGL 数据库的Employees 表中的DepartmentID 列建立索引。
在MySQL 客户端输入如下命令并执行:
create index depart_ind
on Employees(DepartmentID);
② 在Employees 表的Name 列和Address 列上建立复合索引。
create index Ad_ind
on Employees(Name, Address);
③ 对Departments 表上的DepartmentName 列建立唯一性索引。
create unique index Dep_ind
on Departments(DepartmentName);
【思考与练习】
a .索引创建完后可以使用SHOW INDEX FROM tbl_name 语句查看表中的索引。
b .对Employees 表的Address 列进行前缀索引。
c .使用CREATE INDEX 语句能创建主键吗?
(2)使用ALTER TABLE 语句向表中添加索引
① 向Employees 表中的出生日期列添加一个唯一性索引,姓名列和性别列上添加一个复合索引。
使用如下SQL 语句:。
4实验报告
实验内容与完成情况:
一、三类完整性的实现
对系表Dept、学生表Student、教师表Teacher、课程表Course、SC表,教师授课表TC,实现规定的完整性,并验证,当操作违反了完整性约束条件时,DBMS如何处理。
--1、Dept表
--? DEPTNO CHAR()
--? E VARCHAR()DNAM
--? 实体完整性:DEPTNO为主码;
--? 用户定义完整性
--①DEPTNO的取值为至;
--②DNAME取值非空且唯一;
CREATE TABLE DEPT
(DEPTNO CHAR(2)PRIMARY KEY
constraint c1 check(DEPTNO between 01 and 99),
DNAME VARCHAR(20)
constraint c2 NOT NULL unique,
);
--2、Student表
-- SNO CHAR()
-- SNAME VARCHAR()
-- SEX CHAR()
-- DEPTNO CHAR()
--
--实体完整性:SNO为主码;
--参照完整性:DEPTNO为外码,并实现级联更新和级联删除操作;
--用户定义完整性
--①SNO取值为级的学号取值范围,如等。
--②SNAME 取值非空;
--③SEX的取值只能为男或女;
CREATE TABLE Student
(SNO CHAR(10)PRIMARY KEY
constraint b1 check(SNO between 2010080000 and 2010089999), Sname varCHAR(8)NOT NULL unique,
Ssex CHAR(2)
constraint b2 check(Ssex in('男','女')),
DEPTNO CHAR(2),
FOREIGN KEY(DEPTNO)REFERENCES DEPT(DEPTNO)
on delete cascade
on update cascade
);
drop table Student
--3、Teacher表
-- TNO CHAR()
-- TNAME VARCHAR()
-- DEPTNO CHAR()
--
--实体完整性:TNO为主码;
--参照完整性:DEPTNO为外码,并实现级联更新和级联删除操作;
--用户定义完整性
--①TNO取值为开头的四位数字字符串;
--②TNAME取值非空;
CREATE TABLE Teacher
(TNO CHAR(3)PRIMARY KEY
constraint a1 check(TNO between 0800 and 0899),
TNAME varCHAR(8)NOT NULL,
DEPTNO CHAR(2),
FOREIGN KEY(DEPTNO)REFERENCES DEPT(DEPTNO)
on delete cascade
on update cascade
);
drop table Teacher
--4、Course表
-- CNO CHAR()
-- TNO CHAR()
-- CNAME VARCHAR()
-- CREDIT SNALLINT
--
--实体完整性:CNO;
--用户定义完整性
--①CNAME取值非空;
--②CREDIT取值为至以内的数字;
--参照完整性:TNO为外码,并实现级联更新和级联删除操作;
CREATE TABLE Course
(CNO CHAR(4),
TNO CHAR(3),
CNAME CHAR(20)NOT NULL,
CREDIT INT check(CREDIT>=1 and CREDIT<=10),
PRIMARY KEY(CNO),
FOREIGN KEY(TNO)REFERENCES Teacher(TNO)
on delete cascade
on update cascade,
);
drop table Course
--5、SC表
-- SNO CHAR()
-- CNO CHAR()
-- GRADE SMALLINT
--
--实体完整性:(SNO,CNO)为主码;
--参照完整性:SNO外码、CNO外码,都实现级联删除和级联更新操作;
--用户定义完整性
-- GRADE取值在到之间。
CREATE TABLE SC
(SNO CHAR(10),
CNO CHAR(4),
GRADE SMALLINT check(GRADE>=0 and GRADE<=100),
PRIMARY KEY(SNO,CNO),
FOREIGN KEY(SNO)REFERENCES Student(SNO)
on delete cascade
on update cascade,
FOREIGN KEY(CNO)REFERENCES Course(CNO)
on delete no action
on update no action,
);
--二、触发器的实现
--1、修改Student表,增加属性CNT,SMALLINT型,表示学生的选课门数,设置CNT的默认值为。
--增加属性SZK,SMALLINT型,表示素质选修课学分。
ALTER TABLE Student ADD CNT SMALLINT;
ALTER TABLE Student ADD SZK SMALLINT;
--在Student表上创建以下触发器。