《数据库的完整性控制》实验报告

合集下载

数据库完整性实验总结(必备6篇)

数据库完整性实验总结(必备6篇)

数据库完整性实验总结第1篇时间流水,短短的两周就流逝了,回想在这两周的实训生活,我从单一,片面的学习进入了全面,系统的学习,学好它更是一项大任务。

而对于如何学好它,光靠理论知识是远远不够的,_同志曾经就说过“实践是检验真理的唯一标准”!正如大师傅炒菜,知道炒菜的程序,主料、调料一清二楚,不真正掌勺,永远也成不了“大厨”。

而学校给我们提供了这样一个机会,让我们自己_掌勺_,使我们从实践中,加深了对数据库的理解。

经过这次的实训,我们对数据库有了更深的了解,从书面的明白到实践的理解,接触到了自己以前没有接触到的东西,并让我加深了数据库知识的学习和理解,也使我进一步了解数据库,这次实训可以为我们以后真正的实际数据库系统设计提供很好的借鉴。

更使我明白遇到什么挫折,不气馁,不放弃,勇于探索,才会让自己离成功越来越近!俗话说:知之为知之,不知为不知!不要不懂装懂,有什么不懂的要敢于向_知之者_请教!知识是慢慢积累而成的,我们学习不仅要学习理论知识,而实践也是非常重要的,只有当两者结合,才会获得收获!我们这次实习对我们的认识起到了很大的启发作用,使我们以后在接触数据库的过程中少走点弯路。

也使我们对人生和社会有了更清楚的认识,任何的成功都有艰辛和汗水铺出来的,没有那么多的意外收获。

我们要学的还有很多,要接触的还不知道有多少,以后的路还很漫长,我相信我会更加努力的,把握现在,为自己的未来而奋斗,展开双翅飞向美好的未来!在这里很感谢xxx老师给我们传授了这么多的知识和经验,让我们在毕业之际更好的填补自己的不足。

数据库完整性实验总结第2篇在学习《数据库原理及应用》这门课之前,就和课本上提到的一个观点一样,认为它只是存放数据的仓库而已,但是现在我深深体会到这个观点是多么的片面。

数据库是长期存储在计算机内,有组织、可共享的大量的数据集合,前者只能表达它的一方面而已。

数据库技术发展到今天已经是一门非常成熟的技术,它的技术水平、应用水平多比初始时都有了很大的改变,但是它的最基本的特征却没有变,概括起来有以下几个方面:第一点:数据库是相互关联的的数据集合;即在数据库中不仅要能够表示数据本身,还要能够表示数据与数据之间的关系。

数据控制-完整性控制报告

数据控制-完整性控制报告

数据控制-完整性控制实验报告班级07计算机姓名马兆亮日期2010-05-07 同组人(无)指导教师金华评分数据控制-完整性控制部分实验一、实验目的熟悉通过SQL对数据进行完整性控制二、实验设备操作系统为Microsoft Windows 2000数据库管理系统为Microsoft SQL Server 2000个人版或标准版微型计算机:奔腾Ⅳ,每人一台三、实验步骤建立STUDENT、COURSE、SC表,向各表插入若干记录。

CREATE TABLE Student /*创建student表*/(sno char(10),sname char(20) NOT NULL,ssex char(5),sage SMALLINT,dno char(5));CREATE TABLE Course/*创建course表*/(cno char(10),cname char(20) NOT NULL,tno char(10),ccredit int,cpno char(5));CREATE TABLE Sc/*创建Sc表*/(sno char(10),cno char(10) ,cgrade char(5));/*向Student表中添加记录*/INSERT INTO Student VALUES('1001','库克','女',20,'01');INSERT INTO Student VALUES('1002','张小芳','女',21,'03');INSERT INTO Student VALUES('1003','李建','男',23,'02');INSERT INTO Student VALUES('1004','王雨','男',21,'03');INSERT INTO Student VALUES('1005','任娜','女',22,'02');/*向Course表中添加记录*/INSERT INTO Course VALUES('001','数据库','1003',5,'005');INSERT INTO Course VALUES('002','操作系统','1001',5,null);INSERT INTO Course VALUES('003','网络编程','1002',4,'001');INSERT INTO Course VALUES('004','微机原理','1003',6,'002');INSERT INTO Course VALUES('005','C 语言','1001',4,null);/*向Sc表中添加记录*/INSERT INTO Sc VALUES('1001','001',74);INSERT INTO Sc VALUES('1001','002',68);INSERT INTO Sc VALUES('1001','003',79);INSERT INTO Sc VALUES('1001','004',83);INSERT INTO Sc VALUES('1001','005',92);INSERT INTO Sc VALUES('1002','001',73);INSERT INTO Sc VALUES('1002','002',88);INSERT INTO Sc VALUES('1002','003',73);INSERT INTO Sc VALUES('1002','004',87);INSERT INTO Sc VALUES('1002','005',85);INSERT INTO Sc VALUES('1003','001',80);INSERT INTO Sc VALUES('1003','002',71);INSERT INTO Sc VALUES('1003','003',80);INSERT INTO Sc VALUES('1003','004',null);INSERT INTO Sc VALUES('1003','005',69);INSERT INTO Sc VALUES('1004','001',86);INSERT INTO Sc VALUES('1004','002',96);INSERT INTO Sc VALUES('1004','003',79);INSERT INTO Sc VALUES('1004','004',83);INSERT INTO Sc VALUES('1004','005',null);INSERT INTO Sc VALUES('1005','001',84);INSERT INTO Sc VALUES('1005','002',69);INSERT INTO Sc VALUES('1005','003',94);INSERT INTO Sc VALUES('1005','004',85);INSERT INTO Sc VALUES('1005','005',77);1.建立3个表的主码建立Student的主码,两条语句分别执行:ALTER TABLE Student ALTER COLUMN sno char(10) NOT NULL;ALTER TABLE Student ADD CONSTRAINT PK_Student PRIMARY KEY(sno);建立Course的主码,两条语句分别执行:ALTER TABLE Course ALTER COLUMN cno char(10) NOT NULL;ALTER TABLE Course ADD CONSTRAINT PK_Course PRIMARY KEY(cno);建立Sc表的主码,三条语句分别执行:ALTER TABLE Sc ALTER COLUMN sno char(10) NOT NULL;ALTER TABLE Sc ALTER COLUMN cno char(10) NOT NULL;ALTER TABLE Sc ADD CONSTRAINT PK_Sc PRIMARY KEY(sno,cno); 2.为SC表建立参照完整性约束ALTER TABLE Sc ADD CONSTRAINT FK_sno FOREIGN KEY REFERENCES Student(sno);ALTER TABLE Sc ADD CONSTRAINT FK_cno FOREIGN KEY REFERENCES Course(cno);3.设SC表的成绩属性不允许取空值ALTER TABLE Sc ALTER COLUMN cgrade smallint NOT NULL;验证:当插入语句为:INSERT INTO Sc V ALUES('1078','305',null);4.建立部门表(DEPT),属性包括部门编号、部门名称、地址,部门名称要求取值唯一,部门编号为主码CREATE TABLE Dept(sdept char(10) PRIMARY KEY,dname char(20) UNIQUE,dadd char(50),);5.为STUDENT表添加约束:性别的值只允许取“男”或“女”,学号范围为10000-19999,姓名不能取空值ALTER TABLE StudentADD CONSTRAINT S1 CHECK (ssex in('男','女'));验证:当插入记录:INSERT INTO Student V ALUES('1024','石一飞','男',23,'03');显示如下信息:ALTER TABLE Student WITH NOCHECKADD CONSTRAINT S3 CHECK (sno>='10000'and sno <='19999');验证:当插入记录为:INSERT INTO Student V ALUES('2064020220','王龙','男',23,'01');显示如下信息:6.STUDENT表的“所属系”定义为外码,并定义级联删除、级联修改ALTER TABLE Student ADD CONSTRAINT S5 FOREIGN KEY REFERENCES Dept(Sdept) ON DELETE CASCADE ON UPDATE CASCADE7.删除SC表的成绩属性的约束ALTER TABLE Sc DROP CONSTRAINT cgrade;8.SC表的成绩属性取值范围设为0-100分ALTER TABLE Sc ADD CONSTRAINT cgrade CHECK (cgrade >=0 and cgrade <=100);验证:当插入数据:INSERT INTO Sc V ALUES('1005','005',103);显示如下信息:9.对SC表建立插入-更新触发器,当所插入或更新的成绩值超过100分,则警告,并拒绝接收新值CREATE TRIGGER insert_update ON Sc For INSERT, UPDATEASIF (SELECT count(*) FROM insertedWHERE cgrade > 100) > 0BEGINPRINT ' insert_update error: you insert the grade > 100'ROLLBACK TRANSACTIONEND验证:当输入INSERT INTO Sc V ALUES('1086','002',703);显示如下信息10.对COURSE表建立插入-更新触发器,学时小于等于32学时时学分不能超过2分,学时小于等于64学时时学分不能超过4分,任何课程的学分最高不能超过5分CREATE Trigger Insert_Or_Update_SalON CourseFOR INSERT , UPDATEASdeclare@thours smallintdeclare@ccredit intselect (@thours=ins.thours and @ccredit=redit) from inserted ins IF(@thours<=32 and ccredit>2)if(@thours>=64 and ccredit<4)if (ccredit>5)beginraiserror ('警告:非法操作!',16,1)rollback transactionend有错误,调试不成功。

数据完整性控制实训报告

数据完整性控制实训报告

一、实训目的数据完整性是指数据在存储、处理、传输等过程中保持其准确性和一致性的能力。

数据完整性控制是保证数据质量的重要手段,对于维护企业信息系统稳定运行、保障企业数据安全具有重要意义。

本次实训旨在通过实际操作,让学生掌握数据完整性控制的方法和技巧,提高数据完整性控制能力。

二、实训环境1. 操作系统:Windows 102. 数据库管理系统:MySQL 5.73. 开发工具:Visual Studio 20194. 实训数据库:自建数据库三、实训原理数据完整性控制主要包括以下三个方面:1. 实体完整性:保证每个数据记录在数据库中是唯一的,即每个数据记录的主键值不能重复。

2. 字段完整性:保证数据记录中各个字段的值符合数据类型、长度、精度等要求。

3. 引用完整性:保证数据记录之间引用关系的正确性,即外键约束。

四、实训过程1. 创建数据库首先,在MySQL中创建一个实训数据库,用于存储实训数据。

```sqlCREATE DATABASE data_integrity;```2. 创建表在实训数据库中创建一个学生信息表,包括学号、姓名、性别、年龄、班级等字段。

```sqlCREATE TABLE students (id INT PRIMARY KEY,name VARCHAR(20) NOT NULL,gender ENUM('男', '女') NOT NULL,age INT NOT NULL,class VARCHAR(20) NOT NULL);```3. 添加实体完整性约束为学号字段添加唯一性约束,保证每个学生记录的学号是唯一的。

```sqlALTER TABLE students ADD UNIQUE (id);```4. 添加字段完整性约束为年龄字段添加检查约束,确保年龄在1到100之间。

```sqlALTER TABLE students ADD CONSTRAINT chk_age CHECK (age BETWEEN 1 AND 100);```5. 添加引用完整性约束为班级字段添加外键约束,引用班级表的主键。

数据库完整性实验报告

数据库完整性实验报告

数据库完整性实验报告数据库完整性实验报告引言数据库完整性是指数据库中数据的准确性、一致性和有效性。

在数据库中,完整性是非常重要的,它保证了数据的可靠性和可信度。

本实验报告旨在介绍数据库完整性的概念、重要性以及实验过程和结果。

一、数据库完整性的概念和重要性数据库完整性是指数据库中的数据应符合规定的约束条件,不应存在冲突、矛盾或不一致的情况。

它包括实体完整性、参照完整性和用户定义的完整性。

1. 实体完整性实体完整性是指数据库中的每个实体都必须具有唯一的标识符。

在关系型数据库中,实体完整性通常通过主键来实现。

主键是一个能唯一标识实体的属性或属性组合,它保证了每个实体的唯一性。

2. 参照完整性参照完整性是指数据库中的外键必须引用已存在的主键。

外键是一个表中的属性,它引用了另一个表的主键。

参照完整性保证了表与表之间的关联关系的正确性和一致性。

3. 用户定义的完整性用户定义的完整性是指用户自定义的约束条件必须满足。

例如,一个表中的某个属性必须满足某种条件,如非空、唯一等。

用户定义的完整性保证了特定业务需求的满足。

数据库完整性的重要性在于保护数据的可靠性和一致性。

它可以防止数据的错误、冲突和不一致,确保数据的准确性和可信度。

同时,数据库完整性也为数据库的安全性提供了基础,防止非法访问和恶意操作。

二、实验过程本实验使用MySQL数据库进行实验。

1. 创建数据库和表首先,创建一个名为"students"的数据库,并在其中创建一个名为"grades"的表。

表"grades"包含三个字段:学生ID、课程名称和成绩。

2. 添加完整性约束在表"grades"中,为学生ID字段添加主键约束,保证每个学生ID的唯一性。

同时,为课程名称字段添加非空约束,保证每个课程都有名称。

3. 添加参照完整性约束在表"grades"中,为学生ID字段添加外键约束,引用了另一个表"students"中的主键。

数据库的完整性和安全性实验报告

数据库的完整性和安全性实验报告

信息工程学院实验报告课程名称:《数据库原理》实验项目名称:数据库的完整性和安全性一、实 验 目 的:(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)。

数据库的完整性实验报告

数据库的完整性实验报告

数据库的完整性实验报告数据库的完整性实验报告引言:数据库的完整性是指数据库中存储的数据必须满足预定的一致性要求,包括实体完整性、域完整性、参照完整性和用户定义的完整性。

本实验旨在通过设计一个简单的数据库,并通过实际操作验证其完整性。

一、实验目的本实验的目的是通过设计和操作数据库,了解数据库的完整性概念,并掌握如何保证数据的完整性。

二、实验环境本实验使用MySQL数据库管理系统,并在Windows操作系统上进行实验。

三、实验步骤1. 创建数据库首先,我们需要创建一个数据库来存储我们的数据。

在MySQL中,可以使用以下命令创建一个新的数据库:```CREATE DATABASE integrity;```2. 创建数据表接下来,我们需要创建一个数据表来存储我们的数据。

假设我们要创建一个学生信息表,包括学生的学号、姓名和年龄。

可以使用以下命令创建该表:```USE integrity;CREATE TABLE students (id INT PRIMARY KEY,name VARCHAR(50),age INT);```3. 插入数据现在,我们可以向刚刚创建的数据表中插入一些数据。

例如,我们可以插入几个学生的信息:```INSERT INTO students (id, name, age) VALUES (1, '张三', 20);INSERT INTO students (id, name, age) VALUES (2, '李四', 22);INSERT INTO students (id, name, age) VALUES (3, '王五', 21);```4. 实体完整性实体完整性是指每个实体都必须具有一个唯一的标识符。

在我们的学生信息表中,学生的学号是唯一的标识符。

为了保证实体完整性,我们可以在创建表时使用PRIMARY KEY约束来定义学号为主键:```CREATE TABLE students (id INT PRIMARY KEY,name VARCHAR(50),age INT);```这样,如果有重复的学号插入到表中,系统会报错并拒绝插入。

实验4 数据库完整性控制

实验4 数据库完整性控制

注意:为了节约大家的宝贵时间,因此给出题目时,会在一定程度上给出相关的语句,大家只需要补充完善相关的SQL语句即可。

实验四数据库完整性控制一、实验目的1.掌握使用T-SQL定义实体完整性的方法。

2. 了解SQL Server违反实体完整性处理措施。

3. 理解参照完整性的含义。

4. 熟练掌握建立外键的方法。

5. 掌握利用FOREIGN KEY…REFERENCES子句以及各种约束保证参照完整性。

6.掌握利用短语NOT NULL、UNIQUE、CHECK保证域完整性。

7. 熟练掌握约束、规则实施用户自定义完整性8.掌握创建触发器的方法,掌握利用触发器规范插入、更新、删除操作的方法。

二、实验内容1、新建数据库School并创建学生表Student,包含以下属性:Sno (CHAR(5))、Sname (CHAR(8))、Ssex (CHAR(1))、Sage (INT)、Sdept (CHAR(20)),并插入数据:( '10000','王敏','F',23,'CS'),('10000','王浩','M',25,'EE'),创建数据库、表以及插入数据的相关语句为:CREATE DATABASE School ;USE SchoolCREATE TABLE Student(Sno CHAR(5),Sname CHAR(8),Ssex CHAR(1),Sage INT,Sdept CHAR(20));INSERT INTO Student values ( '10000','王敏','F',23,'CS');INSERT INTO Student values ('10000','王浩','M',25,'EE');执行完上述语句后查看数据库中student表中的数据。

实验3 MySQL数据库安全性与完整性控制实验实训报告

实验3 MySQL数据库安全性与完整性控制实验实训报告

数据库运维课程实训报告实验3 数据库安全性与完整性控制实验实训名称:成绩教师评语教师签字日期学生姓名学号一、实训目标练习安全性授权方法、安全性和完整性查看的操作方法。

二、实训内容【实验3-1】使用create user创建用户,创建单个用户teacher,创建两个用户teacher1和student。

【实验3-2】通过直接操作MySQL用户表创建用户,创建单个用户teacher2,创建两个用户teacher3和student2(请注意,新版的MySQL可能不支持使用此方法创建新用户)。

【实验3-3】新建一个terminal窗口,使用mysql –u –h -p方式登录teacher。

【实验3-4】再次新建一个terminal窗口,使用mysql –u –h -p方式登录student。

【实验3-5】使用GRANT语句对用户student赋予所有数据库所有表的insert权限和update权限。

【实验3-6】使用GRANT语句对用户student赋予school数据库所有表的select权限。

【实验3-7】使用GRANT语句对用户student赋予school数据库stuinfo表的create 访问权限。

【实验3-8】使用GRANT语句对用户student赋予school数据库stuinfo表的stuno 列上的select访问权限。

【实验3-9】使用GRANT语句对用户student赋予s所有数据库所有表的select访问权限,并设定student每小时最多可使用select操作访问数据库的次数。

【实验3-10】查看表INFORMATION_ER_PRIVILEGES中有关student的信息,查看user表中的内容信息。

【实验3-11】查看表INFORMATION_SCHEMA.SCHEMA_PRIVILEGES,找到student在school数据库下拥有的权限。

【实验3-12】查看表INFORMATION_SCHEMA.TABLE_PRIVILEGES,查找school数据库中stuinfo数据表相关的表权限。

数据库实验报告 数据控制(完整性部分) 实验四

数据库实验报告  数据控制(完整性部分)  实验四

题目:实验4 数据控制(完整性部分)姓名:* * * 日期:2012年4月26日一、实验目的熟悉通过SQL对数据进行完整性控制。

完成作业的上机练习。

二、实验平台在实验1中安装的RDBMS及其交互工具。

三、实验内容和要求使用SQL对数据进行完整性控制(三类完整性、check短语、constraint字句、触发器)。

用实验证实,当操作违反了完整性约束条件时,系统是如何处理的。

根据以下要求认真填写实验报告,记录所有的实验用例。

四、实验报告1、三类完整性,check短语。

关系模型的实体完整性在create table 中用primary key 定义。

定义主码的方法分为定义为列级约束条件和定义为表级约束条件两种。

对多个属性构成的码只能用表级约束条件。

习题5的第6题,要求定义实体完整性(主码)、参照完整性(外码)、check语句,用户定义的完整性(not null)。

代码如下:create table 职工( Dno numeric(4) primary key,Dname char(20) unique,Dbossname char(20),Dnum numeric(4));create table职工( Eplno smallint primary key,Eplname char(20) not null,Eplage smallint check (Eplage<=60),job char(9),Sal numeric(7,2),Dno numeric(4),foreign key(Dno)references部门(Dno) );2、constraint 字句完整性约束命名字句:create table student(SNO NUMERIC(5)CONSTRAINT C1 CHECK (SNO BETWEEN 90000 AND 99999), SNAME V ARCHAR(20)CONSTRAINT C2 NOT NULL,SAGE NUMERIC(3)CONSTRAINT C3 CHECK (SAGE < 30),SSEX V ARCHAR(2)CONSTRAINT C4 CHECK (SSEX IN ('男','女')), CONSTRAINT StudentKey PRIMARY KEY(SNO));1、触发器(1)创建触发器:(after 行级触发器)create trigger insert_or_update_Sal on 职工after insert as update 职工set Sal=12000 where (job='软件工程师')and (Sal<12000)激活触发器:insertinto职工values('24','小露','21','软件工程师','10000','8')(2)插入触发器:create trigger insert_0table on 职工for insertasdeclare @Eplno smallintselect @Eplno=Eplno from insertedupdate 职工set job='软件工程师' where Eplno=@Eplno激活触发器如下图所示:(3)创建触发器:(instead 表级触发器)create trigger J_updateon Jinstead of updateasbeginraiserror('J表的数据不能被修改!',16,10)end激活触发器:update Jset Jname='大众'where Jno='J1'执行顺序为:执行SQL“update”语句—>执行触发器删除触发器:代码:drop trigger J_update;执行结果如下:3、违反完整性约束条件时,系统处理如下:4、实验小结:(1) 遇到的问题:创建before行级触发器时出现问题create trigger insert_or_update_Salbefore insert or update on 职工for each rowas beginif(new.job='软件工程师')and (new.Sal<12000) then new.Sal:= 12000;end if;end;解决方案:待解决??。

实验四数据库完整性实验报告

实验四数据库完整性实验报告

实验四数据库完整性实验报告一实验目的1. 熟悉通过SQL对数据进行完整性控制;2. 针对具体应用要求,设计相应的完整性约束。

二实验工具SQL Server 2005利用SQL Server 2005 SSMS及其SQL查询编辑器。

三实验内容和要求使用SQL对数据进行完整性控制(3类完整性、CHECK短语、CONSTRAIN 子句、触发器)。

用实验证实,当操作违反了完整性约束条件时,系统是如何处理的。

根据以下要求认真填写实验报告,记录所有的实验用例。

具体操作内容:创建以下两个关系模式,并分别插入相应的数据。

职工(职工号,姓名,年龄,职务,工资,部门号)其中职工号为主码;部门(部门号,名称,经理名,地址,电话号码),其中部门号为主码;(1)使用SQL语言定义这两个关系模式,并完成以下完整性约束条件的定义;(a)定义每个模式的主码;(b)定义参照完整性;(c)定义职工的年龄不能小于18岁,并且不能超过60岁;(d)职工的姓名不能为空;(e)职工的工资不能为空,且不能小于800;(f)部门名称不能为空且不能重复,定义约束名为UK_dName;(2)使用SQL语言分别向两个表中插入7行记录,验证上面的各种约束条件;(3)将职工的年龄改为不能小于16岁,并且不能大于65岁;(4)定义一个表tbl_Emp_Log(eNO, eSalary, Username,ModiDate);在职工表上定义修改和插入数据的触发器,将插入的职工号和工资数据填入到Emp_log表中,并记录操作的用户和插入时间;如果修改了职工的工资,也把职工号和修改后的工资数据填入到Emp_log表中,并记录操作的用户和插入时间。

使用SQL语句向职工表中插入数据和修改工资,验证触发器的效果。

四实验报告4.1 实验环境:Windows XPMicrosoft SQL server Management Studio 20054.2 实验内容与完成情况:--新建数据库create database workgouse work--创建以下两个关系模式,并分别插入相应的数据。

数据库完整性实验报告

数据库完整性实验报告

数据库完整性实验报告引言数据库完整性是数据库管理系统中的一个重要概念,用于确保数据库中数据的准确性、有效性和一致性。

本实验旨在通过设计和实现一系列完整性约束,来验证数据库完整性的实际应用。

实验目标本实验的目标是设计并实现以下几种完整性约束:1.实体完整性约束2.参照完整性约束3.用户自定义完整性约束实验环境本实验使用了以下工具和环境:•数据库管理系统:MySQL•编程语言:Python•集成开发环境:Jupyter Notebook实验步骤步骤一:数据库设计首先,我们需要设计一个符合实验需求的数据库。

我们选择一个简单的学生管理系统作为示例,包含以下两个实体:1.学生(Student):包含学生的学号、姓名和年龄。

2.课程(Course):包含课程的课程号、课程名和学分。

步骤二:实体完整性约束实体完整性约束用于保证每个实体在数据库中都有唯一的标识。

在本实验中,我们将为学生实体添加一个主键约束,保证每个学生的学号是唯一的。

CREATE TABLE Student (id INT PRIMARY KEY,name VARCHAR(50),age INT);步骤三:参照完整性约束参照完整性约束用于保证关系数据库中的引用一致性。

在本实验中,我们将为课程实体添加一个外键约束,引用学生实体的主键。

CREATE TABLE Course (id INT PRIMARY KEY,name VARCHAR(50),credits INT,student_id INT,FOREIGN KEY (student_id) REFERENCES Student(id));步骤四:用户自定义完整性约束用户自定义完整性约束是根据具体业务需求自定义的约束条件。

在本实验中,我们将为课程实体添加一个自定义约束,保证学分必须大于等于0。

ALTER TABLE CourseADD CONSTRAINT chk_credits CHECK (credits >=0);实验结果通过以上步骤,我们已经成功设计并实现了实体完整性约束、参照完整性约束和用户自定义完整性约束。

数据库完整性实验报告

数据库完整性实验报告

数据库完整性实验报告第一篇:数据库完整性实验报告实验报告一、实验题目数据库完整性二、实验要求1)建立一个被参照关系test_main,其中id为主键。

.CREATE TABLE test_main(idINT, valueVARCHAR(10), PRIMARY KEY(id));2)建立一个参照关系test_sub,其中id为主键。

CREATE TABLE test_sub(idINT, main_id INT, valueVARCHAR(10), PRIMARY KEY(id));3)使用如下SQL语句插入数据--插入测试主表数据.INSERT INTO test_main(id, value)VALUES(1, 'ONE');INSERT INTO test_main(id, value)VALUES(2, 'TWO');--插入测试子表数据.INSERT INTO test_sub(id, main_id, value)VALUES(1, 1, 'ONEONE');INSERT INTO test_sub(id, main_id, value)VALUES(2, 2, 'TWOTWO');4)使用add constraint语句建立test_ sub表main_id到test_main表id的外键约束 5)删除test_main表中id=1的记录 6)测试完毕后,删除外键约束重新建立外键约束,要求删除主表的记录时候,同时删除子表中相应引用它的记录7)重新尝试第5步中的操作,之后检索test_sub 表,会出现什么结果?测试完毕后,删除外键约束8)重新建立外键约束,要求更新主表的主键时候,同时更新子表外键9)测试更新主表数据,将id=1的记录的id值设为5。

检查test_sub表中的数据是否被同步更新,测试完毕后,删除外键约束10)再次创建外键约束,要求删除主表的时候,同时将子表的main_id 设置为 NULL 11)测试删除主表test_main中id=2的数据,测试检索子表test_sub 测试完毕后,删除外键约束三、实验内容1)CREATE TABLE test_main(idINT, valueVARCHAR(10), PRIMARY KEY(id));2)CREATE TABLE test_sub(idINT, main_id INT, valueVARCHAR(10), PRIMARY KEY(id));3)INSERT INTO test_main(id, value)VALUES(1, 'ONE');INSERT INTO test_main(id, value)VALUES(2, 'TWO');INSERT INTO test_sub(id, main_id, value)VALUES(1, 1, 'ONEONE');INSERT INTO test_sub(id, main_id, value)VALUES(2, 2, 'TWOTWO');4)ALTER TABLE test_subADD CONSTRAINT main_id_cons FOREIGN KEY(main_id)REFERENCES test_main(id);5)delete from test_main where id='1' 无法执行6)alter table test_subdrop constraint main_id_consALTER TABLE test_subADD CONSTRAINT main_id_cons FOREIGN KEY(main_id)REFERENCES test_main(id)on delete cascade;7)delete from test_main where id='1';结果是test_main,和test_sub中的id=1的都被删除了altertable test_subdrop constraintmain_id_cons;8)首先我把上面操作所删除的加上了INSERT INTO test_main(id, value)VALUES(1, 'ONE');INSERT INTO test_sub(id, main_id, value)VALUES(1, 1, 'ONEONE');ALTER TABLE test_subADD CONSTRAINT main_id_cons FOREIGN KEY(main_id)REFERENCES test_main(id)on update cascade;9)update test_main set id='5' where id='1' 结果是main_id也变为了5。

数据库实验9数据控制(完整性).

数据库实验9数据控制(完整性).

实验9 数据控制(完整性部分实验9.1 实体完整性一、实验目的学习实体完整性的建立,以及实践违反实体完整性的结果。

二、实验内容与要求(1在数据库tempdbforintegrity中建立表Stu_Union,包括sno(char(5,sname(char(8,ssex(char(1,sage(int,sdept(char(20五个列,对sno进行主键约束,并且在没有违反实体完整性的前提下插入并更新一条记录CREATE TABLE Stu_Union(sno char(5,sname char(8,ssex char(1,sage int,sdept char(20。

没有什么异常,一切正常(2练习违反实体完整性的插入操作。

无法插入(3练习违反实体完整性的更新操作。

insert stu_union values('12345','张海','M',22,'信工'(4在数据库tempdbforintegrity中建立表Scholarship,包括M_ID(varchar(30,Stu_id (char(10,R_Money(int三个。

首先向该表插入数据,练习当与现有的数据环境不等时,无法建立实体完整性以及参照完整性。

create table Scholarship(M_ID varchar(30,Stu_id char(10,R_Money intinsert Scholarshipvalues('what meaning','12345',10000insert Scholarshipvalues(null,'12346',10000实验9.2 参照完整性一、实验目的学习建立外键,以及利用FOREIGN KEY…REFER ENCES子句以及各种约束保证参照完整性。

二、实验内容(一、参照完整性(1为练习参照完整性,在数据库tempdbforintegrity中建立表Course,包括cno(char(4,cname(varchar(50,cpoints (int三列,令cno为其主键;并且在表Course中插入数据。

数据库原理实验报告-数据库的完整性

数据库原理实验报告-数据库的完整性

实验题目四、数据库的完整性一、实验目的1、掌握使用约束实现数据完整性的方法;2、掌握使用触发器实现数据完整性的方法;二、实验内容和要求1、设置主键约束、外键约束、唯一约束、非空约束、CHECK约束等;2、使用图形用户界面创建触发器、使用SQL语言创建触发器,实现完整性控制;三、实验主要仪器设备和材料1.计算机及操作系统:PC机,Windows 2000/XP或更高版本;2.数据库管理系统:SQL Server 2005或更高版本;四、实验方法、步骤及结果测试(一)、根据实验一中的基本表,使用约束创建数据完整性。

要求:1、删除teaching中的基本表。

按实验一中的各表的定义,重新创建student表、course1)创建各基本表的先后顺序有什么影响?2)在创建各表过程中,遇到了什么问题,是如何解决的?3、通过“ALERT TABLE”语句,完成下列操作:1)为student表的sname列添加唯一约束,并命名。

2)删除course表的非空约束。

3)为sc表的score列添加约束,取值范围为[0,100]。

4)定义域title_domain,取值为{助教,讲师,副教授,教师},检查SQL Server是否3、检查student表sname列的唯一约束插入新的数据记录对新建的唯一约束进行检查,写出相应的SQL语句,并将检查的执4、检查sc表score列的CHECK约束插入不在定义范围的数据记录检查约束。

写出相应的SQL语句,并将检查执行结果截(二)、通过图形用户界面的方式创建各类约束,定义数据的完整性1、删除sc表的外键约束。

在表设计器中,单击工具栏中的“表和索引属性”按钮,打开2、删除speciality的spname字段唯一约束。

然后在表设计器中,单击工具栏中的“表和3、在表设计器中,单击工具栏中的“表和索引属性”按钮,打开“属性”对话框,在“CHECK 约束”选项中,为teacher表中的title列设置检查约束,定义取值范围为{助教、讲师、副(三)、使用触发器实现数据的完整性1、在student表中创建触发器,实现student和sc表的级联删除。

数据库数据库的完整性控制实验报告

数据库数据库的完整性控制实验报告

实验报告课程名称:数据库原理与应用上机实验名称:数据库的完整性控制专业班级:计算机科学与技术1103 指导教师:卫凡学生姓名:贾梦洁学期:2013-2014学年第一学期实验报告课程名称数据库原理与应用实验名称数据库的完整性控制姓名贾梦洁学号 201107010330专业班级计1103实验日期2013年12月19日成绩指导教师卫凡一、实验目的1. 加深对数据库完整性控制作用的认识和各种完整性约束概念的理解。

2. 熟练掌握数据库完整性约束方法。

二、实验环境硬件环境:PC机软件环境:操作系统为Microsoft Windows 2000或以上版本。

数据库管理系统为Microsoft SQL Server 2000标准版或企业版。

三、实验容1. 熟悉利用企业管理器为列创建DEFAULT约束、为列创建CHECK约束、为列创建UNIQUE 约束、为列创建不允许为空约束、创建PRIMARY KEY约束、创建FOREIGN KEY约束。

2. 熟悉利用企业管理器将各种完整性约束删除。

3. 熟悉利用SQL为列创建DEFAULT约束、为列创建CHECK约束、为列创建UNIQUE约束、为列创建是否为空、创建PRIMARY KEY约束、创建FOREIGN KEY约束。

4. 熟悉利用SQL将各种完整性约束删除。

四、实验步骤1.在实验1中已经对学生_课程数据库中建立了学生、课程和选课3个表,其表结构为:学生S(学号,,性别,年龄,所在专业名称)课程C(课程号,课程名,任课教师名,开设的学期)选课SC(学号,课程号,成绩)利用企业管理器增加如下的完整性约束:(1)限定学生“性别”列的值只能是“男”或“女”的CHECK约束;(2)为“性别”列上创建一个默认约束,默认值为“男”;(3)为“”列上创建一个惟一性约束(即UNIQUE约束);(4)将“年龄”列设置为允许为空字段。

2.利用企业管理器建立学生、课程和选课3个表的表级约束(包括主键约束和外键约束)。

数据库原理数据的完整性实验报告.

数据库原理数据的完整性实验报告.

***大学计算机科学与信息学院软件工程系上机实验报告《数据库原理》实验报告题目实验8 数据的完整性姓名***班级***日期***实验环境:SQL Server 2000一、实验目的熟悉通过SQL对数据进行完整性控制,通过实验加深对数据完整性的理解。

相关知识触发器是实施复杂完整性的一种机制。

触发器不需要专门的语句调用,当对它所保护数据进行修改时由DBMS自动激活,以防止对数据进行不正确,未授权或不一致的修改。

创建触发器的语法为:CREATE TRIGGER < 触发器> ON <表名>[WITH ENCRYPTION]FOR {[DELETE][,][INSERT][,][UPDATE]}[WITH APPEND][NOT FOR REPLICATION]AS <SQL 语句组>其中:1)WITH ENCRYPTION 为加密选项。

2)DELETE 选项为创建DELETE 触发器。

DELETE触发器的作用是当对表执行DELETE操作时触发器被激活,并从指定表中删除元组,同时将删除的元组放入一个特殊的逻辑表(delete表)中。

触发器的动作可以检查delete表中的数据,以确定下一步该如何处理。

3)INSERT选项为创建INSERT触发器。

INSERT触发器在对指定表中执行插入数据操作时激活,激活后将插入表中的数据拷贝并送入一个特殊的逻辑表(inserted 表)中,触发器会根据INSERT表中的值决定如何处理。

4)UPDATE选项为创建UPDATE触发器。

UPDATE触发器仅在对指定表中进行更新数据操作时激活。

UPDATE触发器激活后把将要被更新的原数据移入delete表中,再将要被更新后的新数据的备份送入inserted表中,UPDATE触发器对delete和inserted表进行检查,并决定如何处理。

5)NOT FOR REPLICATION 选项说明当一个复制过程在修改一个触发器表时,与该表相关联的触发器不能被执行。

数据库实验4-数据完整性控制

数据库实验4-数据完整性控制

5.触发器 触发器可以看成是一类特殊的存储过程,在满足某个特定条件时自
动触发执行,是提高数据库服务器性能的有力工具。 触发器分为三类,更新触发器、插入触发器和删除触发器。 能够定义触发器的用户有表的所有者、系统管理员、拥有创建触发
器权限且拥有对操作对象相应操作权限的用户。 1) 定义表TAB,并在其上定义触发器TR1,在对TAB的插入和更新前
SAGE NUMERIC(3) CONSTRAINT C4 CHECK(SAGE<30),
CONSTRAINT STUDENTKEY PRIMARY KEY(SNO) );
2) 修改表student中的完整性约束,去掉对性别的限制,并将对年龄 的限制由小于30改为小于40。
ALTER TABLE STUDENT DROP CONSTRAINT C3; ALTER TABLE STUDENT DROP CONSTRAINT C4; ALTER TABLE STUDENT ADD CONSTRAINT C4 CHECK(SAGE<40);
的值只允许取“男”或“女”;定义表sc,属性GRADE的值在0~100之 间 Student表和sc表的其他信息参加上面的例子 4) 用户定义的元组上约束条件 CHECK短语不仅能够定义属性上的约束条件,而且还能允许用户 定义元组级的约束条件。 定义表student,要求当学生性别为男时,其名字不能以Ms.打头。其 他信息如之前的例子。 4.CONSTRAINT完整性约束命名子句 在定义表时利用约束命名子句对完整性约束条件命名,能够灵活地 增加或删除一个完整性约束条件。 1) 定义表student,要求学号在90000~99999之间,姓名不能取空值, 年龄小于30,性别只能是“男”或“女”。要求全部用约束命名子句 实现,主码约束也要用约束命名子句实现,列信息见之前例子 2) 修改表student中的完整性约束,去掉对性别的限制,并将对年龄 的限制由小于30改为小于40。

数据库安全性及完整性实验报告

数据库安全性及完整性实验报告

数据库安全性及完整性实验报告
一、实验简介
一般来说,数据库的安全性及完整性是指数据库实际上实施的安全性、有效性、正确性和可靠性的控制。

当下的关注点是能够确保数据的有效性、正确性与可靠性,以及确保数据的安全性与完整性。

除此之外,还必须尽
量减少数据被篡改及窃取的可能性,使得数据向客户端分发及共享时不会
受到攻击。

本文旨在测试数据库的安全性及完整性,以及评估对于数据库
的安全性及完整性的影响。

二、实验目的
实验的目的是测试数据库的安全性及完整性,以及评估对于数据库的
安全性及完整性的影响。

三、实验内容
1、建立测试环境
为了测试数据库的安全性及完整性,首先我们需要建立一个测试环境,该测试环境包括:安装和配置数据库服务器,建立数据库,建立表、字段,插入一些测试数据,建立客户端访问数据库的程序。

2、测试数据库的安全性
在测试阶段,我们需要测试数据库的安全性,这个测试有两个方面:(1)授权:测试用户是否可以正确访问指定的数据库和表,而不受
限制。

(2)身份认证:测试数据库服务器的安全性,检查服务器是否能够正确实施身份认证,保证只有授权用户可以访问数据库。

3、测试数据库的完整性。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

实验报告
数据库原理与应用
课程名
称:
数据库的完整性控制
上机实验
名称:
一、实验目的
1. 加深对数据库完整性控制作用的认识和各种完整性约束概念的理解。

2. 熟练掌握数据库完整性约束方法。

二、实验环境
硬件环境:PC机
软件环境:操作系统为Microsoft Windows 2000或以上版本。

数据库管理系统为Microsoft SQL Server 2000标准版或企业版。

三、实验内容
1. 熟悉利用企业管理器为列创建DEFAULT约束、为列创建CHECK约束、为列创建UNIQUE约束、为列创建不允许为空约束、创建PRIMARY KEY约束、创建FOREIGN KEY约束。

2. 熟悉利用企业管理器将各种完整性约束删除。

3. 熟悉利用SQL为列创建DEFAULT约束、为列创建CHECK约束、为列创建UNIQUE约束、为列创建是否为空、创建PRIMARY KEY约束、创建FOREIGN KEY约束。

4. 熟悉利用SQL将各种完整性约束删除。

四、实验步骤
1.在实验1中已经对学生_课程数据库中建立了学生、课程和选课3个表,其表结构为:
学生S(学号,姓名,性别,年龄,所在专业名称)
课程C(课程号,课程名,任课教师名,开设的学期)
选课SC(学号,课程号,成绩)利用企业管理器增加如下的完整性约束:
(1)限定学生“性别”列的值只能是“男”或“女”的CHECK约束;
(2)为“性别”列上创建一个默认约束,默认值为“男”;
(3)为“姓名”列上创建一个惟一性约束(即UNIQUE约束);
(4)将“年龄”列设置为允许为空字段。

2.利用企业管理器建立学生、课程和选课3个表的表
级约束(包括主键约束和外键约束)。

3. 利用企业管理器删除已建立的各种完整性约束。

删除结果:
4.利用Transact-SQL以列约束形式为现有的学生S 表在“学号”属性列上创建主键。

5. 利用Transact-SQL为现有的学生S表中的“性别”列上创建其值只能是“男”或“女”的CHECK约束。

6. 利用Transact-SQL为现有的课程C表中“课程名”列上创建一个惟一性(即UNIQUE)约束。

7. 利用Transact-SQL创建现有学生S表与选课SC表之间的参照完整性约束。

8. 利用Transact-SQL删除学生S表中的“性别”列上创建的CHECK约束。

删除前:
删除后:
9. 利用Transact-SQL自由创建一新表,并在建表同时创建主键约束和域完整性约束。

10. 学生_课程数据库中个表之间的关联关系图。

五、实验总结
鉴于前两次的实验都可以在书上找到,然后就依赖于课本。

没想到这次企业管理器的部分书上根本找不到。

然后一知半解的一步一步做实验,对不对自己也完全不确定。

所以要是上面的过程有错误的地方,我只能说,老师我尽力了_(:зゝ∠)_【←做完实验基本就是这个姿态了】果然太依靠书本也不对。

总之最后一次实验在我看来也是圆满解决了=v=【给自己点个赞~】
接下来还有的两个星期的课程设计也要保持这样的劲头努力起来!最后谢谢老师这一学期教我数据库这门课,虽然依旧还是不能完全掌握。

とにかく、先生お疲れ様でした。

そして、ありがとうございます。

【我是日语初学者,要是有哪里用的不对的地方老师要见谅啦~其实本来还想说私下能不能和你学习日语呢】。

相关文档
最新文档