数据库实验四

合集下载

数据库实验四

数据库实验四

数据库实验四在学习数据库的过程中,实验是帮助我们深入理解和掌握相关知识的重要环节。

本次数据库实验四主要围绕着数据库的查询、更新以及数据完整性等方面展开。

实验的目的是让我们通过实际操作,更加熟练地运用 SQL 语句来处理数据库中的数据,同时加深对数据库原理和概念的理解。

在实验开始之前,我们首先需要准备好相关的数据库环境。

这包括安装数据库管理系统,如 MySQL 或 SQL Server 等,并创建好实验所需的数据库和数据表。

本次实验中,我们创建了一个名为“students”的数据库表,用于存储学生的基本信息,如学号、姓名、年龄、性别和所在班级等。

同时,还创建了一个名为“courses”的表,用于存储课程的信息,包括课程编号、课程名称和授课教师等。

接下来,就是实验的核心部分——数据查询操作。

通过使用 SQL 的 SELECT 语句,我们可以从数据库中获取所需的数据。

例如,要查询所有年龄大于 20 岁的学生信息,可以使用以下语句:```sqlSELECT FROM students WHERE age > 20;```除了简单的条件查询,我们还学习了如何进行多表连接查询。

比如,要获取同时选修了“数据库原理”和“操作系统”两门课程的学生信息,就需要将“students”表、“courses”表以及选课关系表进行连接查询。

数据更新操作也是实验中的重要内容。

通过使用 UPDATE 语句,我们可以对数据库中的数据进行修改。

但在进行数据更新时,一定要谨慎操作,确保更新的结果符合预期,避免造成数据的错误或丢失。

例如,如果要将某个学生的年龄增加一岁,可以使用以下语句:```sqlUPDATE students SET age = age + 1 WHERE student_id ='_____';```在实验过程中,数据完整性的维护也是至关重要的。

我们通过设置主键、外键以及各种约束条件,来确保数据的准确性和一致性。

数据库运维形考实验4

数据库运维形考实验4

数据库运维形考实验4实验训练4:数据库系统维护作业实验目的:本实验旨在通过创建和维护数据库,掌握Mysql数据库的创建和维护的不同方法和途径,并理解实际数据库所包含的各要素。

实验内容:1.数据库创建与维护1)创建学生选课数据库中所包含的数据库表,包括学生、课程和选修表,要求为各数据库表属性选择合适的数据类型,并确定列名、数据类型、是否允许空值等。

2)查看和修改表结构,选择一个数据库表,练对其表结构进行相应的修改。

3)练用交互式的SQL语句分别完成以上操作。

4)对学生数据库中的三张表分别插入数据。

5)对表中的数据进行修改。

6)对表中的数据进行删除操作。

2.建立视图1)建立学生选修课程信息视图,包括学生学号、姓名、所在系、选修的课程编号、课程名称、成绩。

2)修改以上视图,增加学生所在班级信息。

3)对以上视图进行删除。

实验要求:1.利用SQL Server相关机制,根据具体应用领域创建并维护数据库系统,为后续各个实验提供前期准备。

2.独立完成以上实验内容,并在安装和数据库运行后熟悉SQL SERVER的各种运行管理。

3.完成实验报告。

实验环境:Windows 8 PC机、Mysql配置的环境、Mysql命令行工具、Workbench可视化工具。

实验步骤及结果分析:1.创建student数据库,通过命令行工具输入密码,使用相应数据库,使用create table语句创建数据库表,解决中文乱码问题。

2.进行属性查询操作,通过select语句查询数据库表的属性信息,包括列名、数据类型、约束等。

查询表结构,即查看各个属性和属性的完整性约束等。

使用desc student语句可以展示我们创建的数据的所有信息,包括属性名、类型、默认初始情况和约束等。

在默认数据库中,发现最后一个属性classno的属性为varchar(3),而实际数据中classno是4位数,导致存储时与原数据不匹配。

因此,需要修改该属性为4位长度。

数据库实验四.视图创建和查询

数据库实验四.视图创建和查询

南昌大学实验报告
一、实验项目名称
视图创建和查询
二、实验目的
熟悉视图定义和使用视图查询
三、实验基本原理和内容
请为三建公司项目建立一个供应情况的视图,包括供应商代码,零件代码,供应数量.针对该视图完成下列查询:
(1)找出三建工程项目使用的各种零件代码及其数量
(2)找出供应商S1的供应情况
四、主要仪器设备及耗材
PC机一台
五、实验步骤及实验数据及处理结果
1、创建视图:
CREATE VIEW三建供应情况
AS
SELECT SNO,PNO,QTY
FROM SPJ
WHERE JNO=(SELECT JNO
FROM J
WHERE JNAME='三建')
2、a:找出三建工程项目使用的各种零件代码及其数量
SELECT PNO,SUM(QTY)
FROM三建供应情况
GROUP BY PNO
b:找出供应商S1的供应情况
SELECT*FROM三建供应情况
WHERE SNO='S1'
六、参考资料
卫琳《SQL SERVER 2008数据库应用与开发教程》清华大学出版社2011.6。

数据库运维 形考任务4 实验4 数据库备份与恢复实验

数据库运维 形考任务4 实验4 数据库备份与恢复实验

数据库运维形考任务4 实验4 数据库备份与恢复实验符分隔符为“,”,字段的包裹符号为“””,并使用SELECT 语句对恢复的数据进行检查。

2实验4:数据库备份与恢复实验本实验旨在练数据库备份与恢复的操作方法。

学生可以选择使用MySQL官网提供的实例employees数据库进行实验,也可以自己创建数据库进行备份恢复实验。

具体实验内容如下:1.使用select…into…outfile语句对数据库employees的表departments进行数据导出。

2.使用select…into…outfile语句对数据库employees的表salaries进行数据导出,并使用fields字句指定字段值之间的符号分隔符为“,”,字段的包裹符号为“””。

3.使用mysqldump命令备份数据库中的某个表,对数据库employees的表deparments导出SQL语句。

4.使用mysqldump命令备份单个数据库,对数据库employees的导出SQL语句,并忽略数据表departments。

5.使用mysqldump命令备份多个数据库,对数据库employees、test两个数据库导出SQL语句。

6.使用mysqldump命令导出界定格式文件数据,对数据库employees进行CSV文件数据的导出。

7.使用图形化工具MySQL Workbench导出数据库employees的表departments的CSV格式数据。

8.使用图形化工具MySQL Workbench导出数据库employees的表departments的SQL文件。

9.使用DELETE语句删除employees数据库的表departments的表格数据,使用LOAD DATA INFILE语句,通过实验1导出的文件,对删除的数据进行恢复,并使用SELECT语句对恢复的数据进行检查。

10.使用DELETE语句删除employees数据的表salaries的表格数据,使用LOAD DATA INFILE语句以及FIELDS子句,通过实验2导出的文件,对删除的数据进行恢复,即字段分隔符为“,”,字段的包裹符号为“””,并使用SELECT语句对恢复的数据进行检查。

数据库实验报告四

数据库实验报告四

姓名:学号:专业班级:日期:实验四数据更新、视图的创建与修改一、实验目的1、学会使用INSERT、UPDA TE、DELETE等SQL语句进行数据更新;2、学会使用CREATE、DROP等SQL语句创建和删除视图。

二、实验内容1、在sql server2008中使用INSERT、UPDATE、DELETE语句进行数据更新。

2、在sql server2008中使用CREATE、DROP语句创建和删除视图。

三、实验步骤1、在数据库S-C的三个表中分别插入以下数据:学生表student:课程表course:成绩表sc:2、在sql server2008中:(1) 选择数据库S-C,用INSERT语句向学生表student中插入一个新生记录(学号:95020;姓名:陈东;性别:男;所在系:IS;年龄:18)。

(2) 在数据库S-C中建立一个新表deptage,其中一个字段存放系名,另一个字段存放相应得学生平均年龄;然后对学生表student按系分组求平均年龄,再把系名和平均年龄存入新表中。

3、在sql server2008用UPDA TE语句更改表中数据。

(1) 将所有学生的年龄都增加1岁。

(2) 将IS系全体学生的成绩置零。

(3) 分别运行SQL语句,观察运行结果。

4、在sql server2008中用DELETE语句删除表中数据。

(1) 删除学号为“95020”的学生记录。

(2) 删除IS系所有学生的成绩记录。

(3) 分别运行SQL语句,观察运行结果。

5、在sql server2008中用CREATE语句建立视图。

(1) 建立IS系学生的视图IS_student。

(2) 建立IS系选修了1号课程的学生的视图IS_s1。

(3) 建立IS系选修了1号课程且成绩载90分以上的学生的视图IS_s2。

(4) 分别运行SQL语句,观察运行结果。

6、在查询分析器中用DROP语句删除视图IS_student,并观察结果。

数据库实验四答案

数据库实验四答案

数据库实验四答案--实验四----1.定义“IS”系学生基本情况视图V_IS 并查询结果;create view V_ISasselect *from Swhere Sdept='IS'with check option;select *from V_IS;--2.将S,C,SC表中学生的学号,姓名,课程号,课程名,成绩定义为视图V_S_C_G并查询结果;create view V_S_C_Gasselect S.Sno,Sname,o,Cnamefrom S,C,SCwhere S.Sno=SC.Sno and o=o;select *from V_S_C_G;--3.将各系学生人数,平均年龄定义为视图V_NUM_AVG并查询结果; create view V_NUM_AVGasselect count(Sno) DeptNum ,avg(Sage) DeptAvgAge,Sdeptfrom Sgroup by Sdept;select *from V_NUM_AVG;--4.定义一个反映学生出生年份的视图V_YEAR并查询结果;create view V_YEARasselect Sno,2012-Sage birthdayfrom S;select *from V_YEAR;--5.将各位学生选修课程的门数及平均成绩定义为视图V_AVG_S_G并查询结果;create view V_AVG_S_Gasselect SC.Sno,count(o) CountCno,avg(Grade) AvgGradefrom S,C,SCwhere S.Sno=SC.Sno and o=ogroup by SC.Sno;select *from V_AVG_S_G;--6.将各门课程的选修人数及平均成绩定义为视图V_AVG_C_G并查询结果; create view V_AVG_C_Gasselect count(SC.Sno) Cnum,avg(Grade) AvgGradefrom S,C,SCwhere S.Sno=SC.Sno and o=ogroup by o;select *from V_AVG_C_G;--7.查询平均成绩为90分以上的学生学号、姓名和成绩;select SC.Sno,Sname,avg(Grade) AvgGradefrom S,SCwhere S.Sno=SC.Snogroup by SC.Sno,Snamehaving avg(Grade) >90;--8.查询各课成绩均大于平均成绩的学生学号、姓名、课程和成绩;create view V_AVGasselect o,avg(Grade) AvgGradefrom C,SCwhere o=ogroup by o;selectdistinct S.Sno,Sname,o,Gradefrom S,SC,C,V_AVGwhere S.Sno=SC.Sno and o=V_o and Grade >V_AVG.AvgGrade ;--9.按系统计各系平均成绩在80分以上的人数,结果按降序排列;select Sdept,count(AvgGrade) Numfrom S,V_AVG_S_Gwhere S.Sno=V_AVG_S_G.Sno and AvgGrade > 80group by Sdeptorder by Num desc;--10通过视图V_IS,分别将学号为“S1”和“S4”的学生姓名更改为“S1_MMM”,”S4_MMM”并查询结果;insert into S(Sno,Sname,Ssex,Sage,Sdept) values('200215121','三毛','男',21,'IS');insert into S(Sno,Sname,Ssex,Sage,Sdept) values('200215124','紫薇','女',19,'IS');update V_IS set Sno='S1_MMM' where Sno='200215121'; update V_IS set Sno='S4_MMM' where Sno='200215124'; select *from V_IS;--11.通过视图V_IS,新增加一个学生记录('S12','YAN XI',19,'IS'),并查询结果;insert into V_IS(Sno,Sname,Sage,Sdept) values('S12','YAN XI',19,'IS');select *from V_ISwhere Sno='S12';--11.通过视图V_IS,新增加一个学生记录('S13','YAN XI',19,'MA'),并查询结果;insert into V_IS(Sno,Sname,Sage,Sdept) values('S13','YAN XI',19,'MA');-- Tip:由于该学生是MA系的,当有check约束时将会产生更新错误。

大学生数据库实验课实验四报告

大学生数据库实验课实验四报告

《数据库技术及应用》实验四、SQL语言数据定义语言DDL学生姓名学生班级学生学号指导老师重庆邮电大学计算机学院一.实验内容在Navicat for MySQL 中使用CREATE 命令完成对表、索引、视图、同义词的创建,使用DROP 命令完成对表、索引、视图、同义词的删除,使用ALTER 命令对表结构进行修改及完整性约束的增加、删除。

二.实验步骤1.启动Navicat for MySQL,在MySQL –新建连接中完成连接参数配置。

2.登录到本地数据库服务器后,连接到test 数据库上。

3.用SQL 语句(如下),建立如下所示的表student;4.同理5.同理6. 用Drop Table 语句删除表CourseAa。

7. 用Alter Table 语句更新表ChooseBb,添加一个属性名Bb4,类型Varchar, 长度20,完整性约束设为非空值,缺省值设为字符“系统测试值”。

8. 用Alter Table 语句更新表ChooseBb,添加一个属性名Bb5,类型Varchar, 长度10,完整性约束设为主码。

完成后,表ChooseBb 的设计如下所示。

9. 用Create View 语句建立一个视图View_Choosebb,生成的视图属性名(View_bb1,View_bb2,view_bb3), 其中View_bb1 对应于基表ChooseBb 的Bb1、View_bb2 对应于基表ChooseBb 的Bb4、view_bb3 对应于基表ChooseBb 的Bb5。

完成后,视图View_Choosebb 的设计如下所示。

10.用Drop View 语句删除视图View_Choosebb。

11. 用Create Index 语句对表ChooseBb 的Bb2 属性建立一个升序索引,索引名Index_bb2。

用Create Index 语句对表ChooseBb 的Bb4 属性建立一个降序索引,索引名Index_bb4。

数据库实验4实验报告

数据库实验4实验报告

数据库实验4实验报告一、实验目的本次数据库实验 4 的主要目的是深入了解和掌握数据库中的索引、存储过程以及事务处理等关键技术,通过实际操作和实践,提高对数据库管理系统的运用能力,以及解决实际问题的能力。

二、实验环境本次实验使用的数据库管理系统为 MySQL 80,操作系统为Windows 10。

实验在个人电脑上进行,配置为英特尔酷睿 i5 处理器,8GB 内存。

三、实验内容与步骤(一)索引的创建与使用1、首先,创建了一个名为`students` 的表,包含`id`(主键,自增)、`name`(姓名)、`age`(年龄)、`grade`(年级)等字段。

```sqlCREATE TABLE students (id INT AUTO_INCREMENT PRIMARY KEY,name VARCHAR(50),age INT,grade VARCHAR(20));```2、向表中插入了一些示例数据,用于后续的实验操作。

```sqlINSERT INTO students (name, age, grade)VALUES ('张三', 18, '大一'),('李四', 19, '大二'),('王五', 20, '大三'),('赵六', 21, '大四');```3、为`name` 字段创建了一个普通索引,观察查询性能的变化。

```sqlCREATE INDEX idx_name ON students (name);```4、执行查询语句,对比创建索引前后的查询时间。

```sqlSELECT FROM students WHERE name ='张三';```(二)存储过程的创建与调用1、创建了一个简单的存储过程,用于计算两个数的和。

```sqlDELIMITER //CREATE PROCEDURE add_numbers(IN num1 INT, IN num2 INT, OUT result INT)BEGINSET result = num1 + num2;END//DELIMITER ;```2、调用存储过程,传递参数并获取结果。

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

西南石油大学实验报告
注意:在粘贴截图时请保留窗口完整标题,但只需保留关键界面,多余的空白界面请删除。

一、实验课时:2
二、实验目的
(1) 掌握使用T-SQL语句创建登录帐户的方法。

(2) 掌握使用T-SQL语句创建数据库用户的方法。

(3) 掌握使用T-SQL语句创建数据库角色的方法。

(4) 掌握使用T-SQL语句管理数据库用户权限方法。

三、实验要求
(1) 使用SQL Server 2008查询分析器。

(2) 严格依照操作步骤进行。

四、实验环境
(1) PC机。

(2) SQL Server 2008。

五、实验内容及步骤
注意事项:
(1)首先在C盘根目录创建文件夹Bluesky,执行脚本文件
“PracticePre-第11章安全管理.sql”,创建数据库BlueSkyDB
和表;
(2)如何建立“数据库引擎查询”;
(3)使用“select user_name()”可查询当前登录账号在当前数据库中的用户名。

步骤1 使用Transact-SQL创建三个SQL Server登录账户TUser1、TUser2、TUser3,初始密码均为“123456”。

--SA
CREATE LOGIN TUser1
WITH PASSWORD='123456'
CREATE LOGIN TUser2
WITH PASSWORD='123456'
CREATE LOGIN TUser3
WITH PASSWORD='123456'
步骤2 使用TUser1建立一个新的数据库引擎查询,在“可用数据库”下拉列表框中是否能看到并选中BlueSkyDB数据库为什么
不可以选中BlueSkyDB数据库。

因为此时sa还没有赋予TUser1选中BlueSkyDB数据库的权限,TUser1还不是BlueSkyDB数据库的用户。

步骤3 使用Transact-SQL将SQL Server登录账户TUser1、TUser2、TUser3映射为数据库BlueSkyDB的用户,用户名同登录名。

CREATE USER TUser1
CREATE USER TUser2
CREATE USER TUser3
步骤4 再次使用TUser1建立一个新的数据库引擎查询,这次在“可用数据库”下拉列表框中是否能看到并选中BlueSkyDB数据库为什么
可以选中BlueSkyDB数据库。

此时sa已经赋予了TUser1访问BlueSkyDB 数据库的权利了。

步骤5 用TUser1用户在BlueSkyDB数据库中执行下述语句,能否成功为什么
SELECT * FROM BOOKS;
不能成功。

其实TUser1只是具有访问数据库的权限,还没有拥有操作数据库的权限。

步骤6 授予TUser1具有对BOOKS表的查询权限,授予TUser2具有对CUSTOMERS表的插入权限。

GRANT SELECT ON BOOKS TO TUser1
GRANT SELECT ON CUSTOMERS TO TUser2
步骤7 用TUser2建立一个新的数据库引擎查询,执行下述语句,能否成功为什么
不能成功。

因为sa并没赋予TUser2对于CUSTOMERS表进行插入的权限。

INSERT INTO CUSTOMERS VALUES('张三','','123456'); (注意:CUSTOMERS表中的customerID列为自增列)
再执行下述语句,能否成功为什么
SELECT * FROM CUSTOMERS;
成功了。

因为sa赋予了TUser2对于CUSTOMERS表进行查询的权限。

步骤8 在TUser1用户建立的数据库引擎查询中,再次执行下述语句:
SELECT * FROM BOOKS;
成功了。

因为sa赋予了TUser1查询BOOKS表的权限。

这次能否成功但如果执行下述语句:
INSERT INTO CUSTOMERS VALUES('李四','','123456');
能否成功为什么
不能成功。

因为sa没有赋予User1插入数据到BOOKS表的权限。

步骤9 授予TUser3具有在BlueSkyDB数据库中的建表权限。

GRANT CREATE TABLE TO TUser3
步骤10 使用Transact-SQL在数据库BlueSkyDB中创建一个角色
TRole1,并使用Transact-SQL将对BlueSkyDB数据库中Books表的增、删、改、查权限授予角色TRole1。

CREATE ROLE TRole1
GRANT SELECT,INSERT,DELETE,UPDATE
ON Books TO TRole1
步骤11 新建立一个SQL SERVER身份验证模式的登录名:pub_user,并让该登录名成为BlueSkyDB数据库中的合法用户(非常重要,否则后面无法将其加入TRole1角色)
CREATE LOGIN pub_user
WITH PASSWORD='123456'
CREATE USER pub_user
步骤12 用pub_user建立一个新的数据库引擎查询,执行下述语句,能否成功为什么
SELECT * FROM BOOKS;
不能成功。

此时pub_user并没有被sa赋予对books表的查询权限。

步骤13 将pub_user用户添加到TRole1角色中。

EXEC sp_addrolemember'TRole1',
'pub_user'
步骤14 在pub_user建立的数据库引擎查询中,再次执行下述语句,能否成功为什么
SELECT * FROM BOOKS;
成功了。

因为把pub_user加入到角色TRole1里,他拥有了TRole1的所有操作权限。

步骤15 使用Transact-SQL将对BlueSkyDB数据库中Books表的删除、更新和查询的权限从角色TRole1处回收回来。

EXEC sp_droprolemember'TRole1',
'pub_user'
步骤16在pub_user建立的数据库引擎查询中,再次执行下述语句,能否成功为什么
不能成功。

因为pub_user被加入到TRole1角色里,他们相当于捆绑在一起。

但TRole1失去权利时,pub_user也失去相应的权利。

SELECT * FROM BOOKS;
六、收获,体会及问题
(请详细书写,写得越详细、越个性化、越真实越好,否则我不知道你做这个实验的心路历程,也就无法充分地判断你是否是独立完成的这个实验、你是否在做这个实验时进行了认真仔细地思考、通过这个实验你是否在实践能力上得到了提高)
本次实验主要是通过SQL的数据库控制语言来实现用户对数据库的操作权限的控制。

用户的操作权限设置有三层,第一层是否具有登录数据库服务器的权限;第二层是是否具有访问数据库的权限。

第三层是是否具有操作数据库数据的权限。

每一层都有其固定的语句来设置。

并且是层层递进。

学会了如何创建一个角色,并且将为这个角色授予相关的权限,当有新的用户被添加到这个角色的时候,这个用户就会具备这个角色的所有权限。

但角色的权限被删除时,在角色里的用户也会失去角色所拥有的权限。

不过自己也是照着PPT做的,还必须要加强联系,巩固记忆。

相关文档
最新文档