文档详情

数据完整性与安全性控制.docx

发布:2017-01-22约2.8千字共13页下载文档
文本预览下载声明
《数据库原理》实验报告题目:实验三数据完整性与安全性控制学号姓名班级日期2016/10/18实验内容、步骤以及结果利用图形用户界面对实验一中所创建的Student库的S表中,增加以下的约束和索引。非空约束:为出生日期添加非空约束。主键约束:将学号(sno)设置为主键,主键名为pk_sno。唯一约束:为姓名(sname)添加唯一约束(唯一键),约束名为uk_sname。缺省约束:为性别(ssex)添加默认值,其值为“男”。CHECK约束:为SC表的成绩(grade)添加CHECK约束,约束名为ck_grade,其检查条件为:成绩应该在0-100之间。外键约束:为SC表添加外键约束,将sno,cno设置为外键,其引用表分别是S表和C表,外键名称分别为fk_sno,fk_cno。在图形用户界面中删除以上小题中已经创建的各种约束,用SQL语言分别重新创建第1题中的(2)-(6)小题.(提示:alter table add constraint)(2) USE [Student] GOALTER TABLE SADD CONSTRAINT pk_sno PRIMARY KEY(sno);(3)USE [Student] GOALTER TABLE SADD CONSTRAINT uk_sname UNIQUE(sname);(4)USE [Student] GOALTER TABLE SADD CONSTRAINT A DEFAULT(男) FOR ssex;(5)USE [student] GOALTER TABLE SC ADD CONSTRAINT ck_grade CHECK(grade BETWEEN 0 AND 100);(6) USE [student] GOALTER TABLE SCADD CONSTRAINT fk_sno FOREIGN KEY(sno) REFERENCES S(sno) ALTER TABLE SCADD CONSTRAINT fk_cno FOREIGN KEY(cno) REFERENCES C(cno);利用图形用户界面根据上述SC表中的外键定义画出由S,C,SC表构成的数据库关系图。(提示:选中student - 数据关系图)用SQL语言删除S表中所创建的缺省约束和外键约束。USE [Student] GOALTER TABLE S --缺省约束DROP CONSTRAINT AALTER TABLE SC --外键约束DROP CONSTRAINT fk_sno,fk_cno;在图形用户界面中创建新登录名以及用户。根据第五版教材第四章 第7题,创建数据库company和其中的基本表,并创建该题中所需要用到的各个用户以及相关的登录名。用图形用户界面完成以下的权限赋予:用户王明对两个表均有Select和Insert的权力。 b)用户李勇对职工表具有Select权力,对工资字段具有更新权力。用SQL语句授权和收回权限并对权限加以验证。根据第五版教材第四章 第7题。1. GRANT SELECT ON 职工 TO 王明 GRANT SELECT ON 部门 TO 王明;2. GRANT INSERT,DELETE ON 职工TO 李勇GRANT INSERT,DELETE ON 部门TO 李勇;3.当每个用户连接到数据库要查询时,创建该用户对应的视图,该用户只有对自己的视图有查询权限,下面以杨兰举例。CREATE VIEW yanglanASSELECT *FROM 职工 WHERE 职工.姓名 =CURRENT_USERGRANT SELECTON yanglanTO 杨兰 4..GRANT SELECT,UPDATE(工资)ON 职工TO 刘星5.GRANT ALTERON 职工TO 张新GRANT ALTERON 部门TO 张新6..GRANT ALL PRIVILEGESON 职工TO 周平WITH GRANT OPTIONGRANT ALL PRIVILEGESON 部门TO 周平WITH GRANT OPTION7.CREATE VIEW NEWVIEW(a,b,c,d)ASSELECT 职工.部门号,MAX(工资),MIN(工资),AVG(工资)FROM 职工,部门WHERE 职工.部门号=部门.部门号GROUP BY 职工.部门号GRANT SELECTON NEWVIEW TO 杨兰 根据第五版教材第四章 第8题。 1.REVOKE SELECT ON 职工 TO 王明 REVOKE SELECT ON 部门 FROM 王明2.REVOKE DELETE,INSERT ON 部门FROM 李勇;REVOKE DELETE,INSE
显示全部
相似文档