2022年秋数据库应用实验指导 .pdf

上传人:Q****o 文档编号:25097032 上传时间:2022-07-09 格式:PDF 页数:30 大小:1.68MB
返回 下载 相关 举报
2022年秋数据库应用实验指导 .pdf_第1页
第1页 / 共30页
2022年秋数据库应用实验指导 .pdf_第2页
第2页 / 共30页
点击查看更多>>
资源描述

《2022年秋数据库应用实验指导 .pdf》由会员分享,可在线阅读,更多相关《2022年秋数据库应用实验指导 .pdf(30页珍藏版)》请在得力文库 - 分享文档赚钱的网站上搜索。

1、1 / 30 梁文娟目录实验 1 SQL Server的安装及管理工具的使用2 实验 2 交互式 SQL2 实验 3 数据完整性和安全性管理13 实验 4 触发器和存储过程实验23 实验 5 数据库备份与恢复26 实验 6 数据库设计综合应用27 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 1 页,共 30 页2 / 30 实验 1SQL Server 的安装及管理工具的使用一、实验目的1、通过对某个商用数据库管理系统的使用,了解DBMS 的工作原理和系统构架。在此推荐数据库管理系统SQL Server 2005 ,该系统已经在机房FTP 上。

2、你也可以从微软官方网站上下载该系统。2、熟悉对DBMS 的操作二、实验内容1、根据安装文件的说明安装数据库管理系统。在安装过程中记录安装的选择,并且对所作的选择进行思考,为何要进行这样的配置,对今后运行数据库管理系统会有什么影响。2、学会启动和停止数据库服务,思考可以用哪些方式来完成启动和停止。3、掌握管理工具的使用 (1)SQL Server Management Studio 的使用连接服务器的方法查询编辑器的使用 (2)配置管理器的使用4、了解数据库系统的逻辑组件:它们主要是数据库对象,包括基本表、视图、触发器、存储过程、约束等。今后将学习如何操作这些数据库对象。三、实验报告要求、给出安

3、装过程中出现的错误及解决方法。、根据你所了解的SQL Server 工具,写出部分主要组件的功能(以SQL Server2005 为例,写出SQL Server Management Studio 、配置管理器)。实验 2 交互式 SQL 2.1 创建数据库及表一、实验目的本次实验了解SQL Server 2005 的启动,熟悉如何使用SSMS 和 SQL 建立数据库和表,并加深对于完整性的理解。二、背景知识在使用数据库的过程中,接触最多的就是数据库中的表。表是数据存储的地方,是数据库中最重要的部分,管理好表也就管理好了数据库。表是由行和列组成的。创建表的过程主要就是定义表的列的过程。表的列名

4、在同一个表中具有唯一性,同一列的数据属于同一种数据类型。除了用列名和数据类型来指定列的属性外,还可以定义其它属性:是否为空、默认值、标识符列、全局唯一标识符列等。约束是SQL Server 提供的自动保持数据库完整性的一种方法,定义了可输入表或表的精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 2 页,共 30 页3 / 30 单个列中的数据的限制条件。在SQL Server 中有5 种约束:主关键字约束(Primary Key Constraint ) 、 外 关 键 字 约 束 ( Foreign Key Constraint ) 、 惟 一

5、性 约 束 ( Unique Constraint)、检查约束(Check Constraint)和默认约束(Default Constraint) 。三、实验内容方法 1:在 SSMS 中创建数据库和表在本练习中,将使用SQL Server2005 数据库管理系统创建Student 数据库,并在Student 数据库中创建表Student,使你能够掌握使用SQL Server2005 数据库管理系统创建数据库和表的方法。1)启动 SQL Server2005:依次单击开始所有程序 SQL Server 2005 SQL Server Management Studio 启动SQL Serve

6、r 2005 数据库管理系统2)登录数据库服务器:点击“连接到服务器“对话框中的连接按钮连接到SQL Server 2005 数据库服务器。3)创建数据库Student 在 SQL Server 2005 数据库管理系统的左边栏“对象资源管理器”中右击数据库对象,在弹出的快捷菜单中单击“新建数据库”命令。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 3 页,共 30 页4 / 30 在弹出的“新建数据库”对话框右侧的数据库名称中输入数据库名称“Student” ,然后单击确定。4) 在 Student数据库中新建表” Student”单击SQL

7、Server 2005 数据库管理系统的左侧的“对象资源管理器”栏中的” 刷精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 4 页,共 30 页5 / 30 新”按钮,以显示出新建的数据库“Student” 。依次展开左侧栏对象资源管理器中的“数据库”“Student” ,并右击Student 数据库中的表工程,在弹出的快捷菜单中单击“新建表”命令。在右侧在工作区中输入“Student” 表的信息,该表具有如下列:列名数据类型完整性约束Sno CHAR(5) 主码Sname CHAR(10) 非空Ssex BIT 无Sage INT 无Sdept

8、CHAR(15) 无单击文件菜单中的保存命令保存该表,并取名为“Student”。方法二、使用 SQL 语句创建数据库和表1) 单击工具栏中的“新建查询”按钮,并在弹出的“连接到服务器”对话框中单击“连接”按钮,新建一个SQL 脚本。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 5 页,共 30 页6 / 30 2) 在右侧的SQL 脚本输入框中输入如下SQL 代码:CREATEDATABASE STUDENT - 创建 STUDENT数据库GO USE STUDENT - 转到 STUDENT数据库GO CREATETABLE STUDENT

9、- 在STUDENT数据库中创建表STUDENT ( Sno CHAR( 5) PRIMARYKEY, Sname CHAR ( 10 )NOTNULL, Ssex BIT , Sage INT , Sdept CHAR ( 15 ) ) 单击工具栏中的执行按钮,运行SQL 语句,完成数据库与表的创建。四、实验任务1用两种方法建立一个新数据库HRM (也可任意取名)。2在数据库HRM 中,建立如下所示的三个表:Employee 表列名数据类型长度是否允许为空说明EmployeeID Char 6 否员工编号,主键精选学习资料 - - - - - - - - - 名师归纳总结 - - - - -

10、 - -第 6 页,共 30 页7 / 30 Name Char 10 否姓名Birthday Datetime 8 否出生日期Sex Bit 1 否性别Address Char 20 是地址Zip Char 6 是邮编PhoneNumber Char 12 是电话号码EmailAddress Char 30 是电子邮件地址DepartmentID Char 3 否员工部门号,外键Departments 表列名数据类型长度是否允许为空说明DepartmentID Char 3 否员工部门号,主键DepartmentName Char 20 否部门名Note Text 16 是备注Salary

11、表列名数据类型长度是否允许为空说明EmployeeID Char 6 否员工编号,外键Income Float 8 否收入OutCome Float 8 否支出3.对三张表输入数据(可任意输入,但注意要符合完整性要求,否则会出错,在本实验中,外键设置可先不做要求)五、实验报告要求1、要求给出三个表创建的SQL 语句,要求建表时给出主外键约束、唯一约束、取空值约束、用户自定义的约束等。(注:在实验报告上只需写出其中一个表的SQL 语句即可)2、举例说明如何操作会违背完整性(实体完整性、参照完整性)。2.2 SQL 数据查询语句一、实验目的了解 SQL Server 2005 查询编辑器的启动,熟

12、悉如何在SQL Server 2005 查询编辑器查询记录。掌握 SELECT 语句的基本语法和查询条件表示方法掌握 GROUP BY 和 ORDER BY 子句的作用和使用方法掌握连接查询和子查询的使用方法二、实验内容1、单击工具栏中的“新建查询”按钮,并在弹出的“连接到服务器”对话框中单击“连接”按钮,新建一个SQL 脚本。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 7 页,共 30 页8 / 30 2、在 SQL 脚本中写数据查询语句执行;从表中查询数据:在查询分析器的查询窗口中输入SQL 语句,如图所示。点击按钮,执行该SQL 语句,在

13、查询窗口下部出现一个输出窗口,如图所示。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 8 页,共 30 页9 / 30 三、实验任务1对上节建立的表输入数据:Departments 表:DepartmentID DepartmentName Note 1 财务部财务部2 研发部研发部3 人力资源部人力资源部Employee 表EmployeeID Name Birthday Sex Address Zip PhoneNumber EmailAddress DepartmentID 1001 李勇78-3-12 0 河南475001 3880378

14、 1 1002 王敏80-11-2 1 河南475002 0378311 1 1003 刘晨78-6-22 0 河南475003 0378322 1 2001 张立78-8-1 0 河南475004 0378333 2 2002 刘毅82-1-23 0 河南475005 0378344 2 2003 张玫81-3-15 1 河南475006 0378355 2 3001 徐静76-8-12 1 河南475007 0378366 3 3002 赵军79-2-19 0 河南475008 0378377 3 Salary 表EmployeeID Income OutCome 1001 3600 15

15、00 1002 3300 1000 1003 3700 1200 2001 4000 1600 2002 3800 1800 2003 3800 1500 3001 4200 2000 3002 4100 1800 2、练习下面简单的查询语句:精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 9 页,共 30 页10 / 30 a) 查询每个雇员的所有信息b) 查询每个雇员的地址和电话c) 查询 EmployeeID 为 000001的雇员的地址和电话。d) 查询女雇员地址和电话,并用AS 子句将结果中各列的标题分别指定为“地址”和“电话”。e) 计

16、算每个雇员的实际收入。f) 找出所有姓王的雇员的部门号。思考:找出所有地址中含有“中山”的雇员的号码和部门号。3、练习多表连接查询和嵌套查询:a)查询每个雇员的情况及工资情况(工资=Income - Outcome )b)查询财务部工资在2200元以上的雇员姓名及工资情况c)查询研发部在1966 年以前出生的雇员姓名及其工资详情d)查询人力资源部雇员的最高和最低工资e)将各雇员的情况按工资由低到高排列f)求各部门的雇员数g)找出所有在财务部和人力资源部工作的雇员的编号h)统计人力资源部工资在2500 以上雇员的人数i)求财务部雇员的总人数j)求财务部雇员的平均工资k)查找比所有财务部的雇员工资

17、都高的雇员的姓名l)查找财务部年龄不低于研发部所有雇员年龄的雇员的姓名m) 查找在财务部工作的雇员的情况四、实验报告要求1、写出与上述查询任务相对应的SQL 查询语句(注:在实验报告上写出2-d、2-e、2-f 及3 中所有练习的SQL 语句)2、并记录在实验过程中遇到的问题、解决办法及心得体会。2.3 视图的定义和操作一、实验目的:理解视图的概念,掌握视图的使用方法。二、预计实验时间:上机一次三、实验过程1 对应 HRM 数据库,参照前面实验中完成的查询,按如下要求自行设计视图:1)基于单个表按投影操作定义视图。举例:定义一个视图用以查看所有员工的编号、姓名和出生日期。2)基于单个表按选择操

18、作定义视图。举例:定义一个满足sex=true 的员工的所有信息的视图。3)基于单个表按选择和投影操作定义视图。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 10 页,共 30 页11 / 30 举例:定义一个视图用以查看部门号码为2的所有员工的姓名、电话和邮件地址。4)基于多个表根据连接操作定义视图。举例:定义一个视图用以查看所有员工的姓名、部门名及工资。5)基于多个表根据嵌套查询定义视图。举例:定义一个比所有财务部的雇员工资都高的雇员的信息的视图6)定义含有虚字段(即基本表中原本不存在的字段)的视图。举例:定义一个视图用以查看所有雇员的编号、

19、姓名、年龄。2分别在定义的视图上进行查询、插入、更新和删除操作,分情况(查询、更新)讨论哪些操作可以成功完成,哪些不能成功完成,并分析原因。四、实验报告要求:1、在实验报告中要给出上述任务的视图定义语句;(注:实验报告上写出4、5、6 的 SQL语句)2、分情况讨论哪些操作可以成功完成,哪些不能成功完成。查询操作:举出一个进行查询操作的例子。更新操作:更新操作包含插入、更新、删除,针对不能成功完成更新操作的情况举出两个例子,并分析原因。2.4 SQL 数据更新语句一、实验目的加深对 SQL 数据更新(插入、修改及删除)语句的基本语法格式的掌握掌握单个元组及多个元组的插入、修改及删除操作的实现过

20、程加深对更新操作时数据库中数据一致性问题的了解加深对约束条件在数据更新操作执行中的作用问题的了解二、实验内容方法一:在SSMS 中插入、删除及修改数据,方法二:在查询编辑器中写SQL 插入、删除及修改数据三、实验任务设有一个SPJ数据库,包括S,P,J,SPJ四个关系模式:S(SNO,SNAME ,STATUS,CITY )精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 11 页,共 30 页12 / 30 P(PNO,PNAME ,COLOR ,WEIGHT )J(JNO,JNAME ,CITY )SPJ(SNO, PNO,JNO,QTY )供应

21、商表S 由供应商代码(SNO)、供应商姓名(SNAME )、供应商 (STATUS) 、供应商所在城市( CITY )组成;零 件 表P 由 零 件 代 码 ( PNO ) 、 零 件 名 ( PNAME ) 、 颜 色 ( COLOR ) 、 重 量(WEIGHT )组成;工程工程表J 由工程工程代码(JNO)、工程工程名(JNAME )、工程工程所在城市(CITY )组成;供应情况表SPJ 由供应商代码(SNO)、零件代码(PNO)、工程工程代码(JNO)、供应数量( QTY )组成,表示某供应商供应某种零件给某工程工程的数量为QTY 。试完成以下操作:1在 S表中插入元组“s6,华誉,

22、40,广州”2在 J表中插入元组“j8,传感器厂”3对每一个供应商,求他为各种工程供应零件的总数量,并将此结果存入数据库4将 P表中 PNO 值为 p6 的元组的color 属性值改为绿,weight 属性值改为60 5将 SPJ表中前 4 个元组的qty 属性值统一修改为300 6将 S表中 city 属性名含有“京”或“津”的相应status属性值增加100 7将供应商s2为“一汽”工程工程所供应的零件数量修改为2000 8将全部红色零件的颜色修改为浅红色9由 s5 供给 j4 的零件 p6 改为由 s3供应10在 SPJ表中新增一名为SDATE 的属性列,对该表中的每一元组在SDATE

23、属性列上填上实验当时的日期和时间11删除所在城市为“广州”的供应商记录精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 12 页,共 30 页13 / 30 12删除所有零件名称中第一个字为“螺”字的零件记录,并在供应情况表中删除相应的记录13删除s3 和 s4 两供应商为“三建”工程供应“螺母”或“螺丝刀”零件的相应供应情况数据信息四、实验报告要求1、写出与上述任务相对应的SQL 更新语句(实验报告上写出3、5、10的 SQL 语句)2、并记录在实验过程中遇到的问题、解决办法及心得体会。实验 3 数据完整性和安全性管理3.1 数据完整性管理一、实验

24、目的掌握域完整性的实现方法。掌握实体完整性的实现方法。掌握参照完整性的方法。二、实验内容数据库的完整性设置。三、实验步骤可视化界面的操作方法:实体完整性 1将student 表的“ sno”字段设为主键:在表设计界面中,单击左边的行选定块,选定“sno”字段,单击工具按钮设置主键。如图1 所示:精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 13 页,共 30 页14 / 30 图 1 1将“ sc”表的“ sno”和“ cno”设置为主键:在表设计界面中,单击并按住Ctrl键拖动左边的行选定块,选定sno和 cno 字段,单击工具按钮设置主键。如

25、图2 所示:图 2 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 14 页,共 30 页15 / 30 域完整性3. 将“ ssex”字段设置为只能取“男”,“女”两值:在表设计界面,点击鼠标右键CHECK约束 , 添加约束,添加CK_student_sex 名称,然后在约束表达式框中输入“ ssex in (男,女) ”。如图3所示。图 3 参照完整性4. 将“ student”表和“ sc”表中的“ sno”字段设为参照: 打开“ sc”表的设计界面, 点击工具栏按钮, 在弹出的属性(properties)对话框中点击“新建”按钮,在“主键表

26、(Primary key table)”下拉框中选择“student”表,在其下的字段选择框中选择“sno”,在“外键表(Foreign key table)”下拉框中选择“sc”表,在其下的字段选择框中选择“sno”,单击关闭即可。见图4。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 15 页,共 30 页16 / 30 图 4 命令方式操作方法:实体完整性1将“ student”表的“ sno”字段设为主键:当“ student”表已存在则执行:alter table student add constraint pk_sno primary

27、 key (sno) 当“ student”表不存在则执行: Create table student(sno CHAR(5) primary key , sname CHAR(10) NOT NULL, ssex CHAR(2), sage int, sdept CHAR(4) 注:可用命令“ drop table student”删除“ student”表2. 添加一身份证号字段,设置其惟一性.(注: 操作前应删除表中的所有记录) Alter table student add id char(18) unique (id) 3. 将“ sc”表的“ sno”和“ cno”设置为主键:当“

28、 sc”表已存在则执行:alter table sc add constraint PK_SnoCno primary key (sno,cno) 当“ sc”表不存在则执行:Create table sc(sno CHAR(5), cno CHAR(2), grade INT NULL, constraint PK_SnoCno primary key (sno,cno) 域完整性4. 将“ ssex”字段设置为只能取“男”,“女”两值:精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 16 页,共 30 页17 / 30 当“ student”表

29、已存在则执行:alter table student add constraint CK_Sex check (ssex in ( 男 ,女) 当“ student”表不存在则执行:Create table student(sno CHAR(5) primary key , sname CHAR(10), ssex CHAR(2) check (ssex in ( 男 ,女) , sage int, sdept CHAR(4) 5. 设置学号字段只能输入数字: alter table student add constraint CK_Sno_Format check (sno like 0-

30、90-90-90-90-9) 6. 设置身份证号的输入格式: alter table student add constraint CK_ID_Format check (id like 0-90-90-90-90-90-91-20-90-90-90-10-90-30-90-90-90-9_) OR (id like 0-90-90-90-90-90-90-90-90-10-90-30-90-90-90-9) 7. 设置 18 位身份证号的第7位到第 10 位为合法的年份(1900-2050) alter table student add constraint CK_ID_Format2 c

31、heck (len(id)=18 and ( (convert(smallint,substring(id,7,4) )=1900) and(convert(smallint,substring(id,7,4) )=22 or ssex=女 and sage=20 ) 参照完整性9. 将“ student”表和“ sc”表中的“ sno”字段设为参照: 当“ sc”表已存在则执行:alter table sc add constraint FP_sno foreign key (sno) references student(sno ) 当“ sc ”表不存在则执行:Create table

32、sc(sno CHAR(5) constraint FP_sno foreign key references student(sno), cno CHAR(2),grade INT NULL, constraint PK_SnoCno primary key (sno,cno) ) 完整性验证1 实体完整性:在“ student”表数据浏览可视化界面中输入学号相同的两条记录将会出现错误如图5 所示:精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 17 页,共 30 页18 / 30 图 5 或者在命令窗口输入下面两条命令也会出现错误提示:inse

33、rtinto student values( 95003, 张三 , 男 , 24 , CS, 42222919901012903X) insertinto student values( 95001, 李四 , 女 , 21 , CS, 422229199510129031) 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 18 页,共 30 页19 / 30 图 6 下面的语句用来验证“sc”表中的实体完整性:insert into sc values(95002, 10,65) insert into sc values(95002, 10,

34、90) 图 7 2. 域完整性 : 使用下面的语句验证“ssex”字段的域完整性:insert into student values(95009, 张匀 ,大,20,CS, 42222919901012904X) 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 19 页,共 30 页20 / 30 3参照完整性:使用下面的语句“验证”sc 表中的“ sno”字段的域完整性(假设student 表中没有学号为“95998”的学生记录 ):insert into sc values(98998, 10,98) 四、实验任务 :1、建立课程的实体完整性

35、, 和课程号cno的参照完整性。2、对HRM 数据库,练习建立三个表的主外键约束、唯一约束、取空值约束、用户自定义的约束(参考HRM 数据库表定义图中说明);3、建立 salary表的 Income 字段限定在0-9999 之间。五、实验报告要求1、写出与上述任务相对应的SQL 语句2、并记录在实验过程中遇到的问题、解决办法及心得体会。3.2 数据库安全性管理一、实验目的精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 20 页,共 30 页21 / 30 掌握 SQL Server 身份验证模式。掌握创建登录账户、数据库用户的方法。掌握使用角色实现

36、数据库安全性的方法。掌握权限的分配。二、实验内容1、设置身份验证模式:Windows 身份验证模式和混合模验证模式。2、设置登录账户3、设置数据库用户4、设置数据库角色。5、设置管理对象的权限三、实验步骤1.设置身份验证模式依次单击开始所有程序 SQL Server 2005SQL Server Management Studio 启动 SQL Server 2005 数据库管理系统连接成功后,右键你的实例,选择属性 在属性 窗口中,转到 Security( 安全性 )项,在 服务器身份验证中设置为 SQL Server和 Windows 身份验证模式, 确定,根据提示,应该重新启动sql 服

37、务然后执行下面的语句启用sa 用户 , 同时清除sa 的密码 (能成功登陆后再根据你的需要设置 ) EXEC sp_password null,null,sa ALTER LOGIN sa ENABLE 语句执行完成后, 再用 sa连接你的实例 , 应该就没有问题了. 2.设置登录账户创建使用 Windows 身份验证 (SQL Server Management Studio) 的 SQL Server 登录名?在 SQL Server Management Studio 中,打开对象资源管理器并展开要在其中创建新登录名的服务器实例的文件夹。?右键单击“安全性”文件夹,指向“新建”,然后单击

38、“登录名”。?在“常规”页上的“登录名”框中输入一个 Windows 用户名。?选择“ Windows 身份验证”。?单击“确定”。创建使用 SQL Server 身份验证 (SQL Server Management Studio) 的 SQL Server 登录名?在 SQL Server Management Studio 中,打开对象资源管理器并展开要在其中创建新登录名的服务器实例的文件夹。?右键单击“安全性”文件夹,指向“新建”,然后单击“登录名”。?在“常规”页上的“登录名”框中输入一个新登录名的名称。?选择“ SQL Server 身份验证”。?输入登录名的密码。?选择应当应用于

39、新登录名的密码策略选项。通常,强制密码策略是更安全的选择。?单击“确定”。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 21 页,共 30 页22 / 30 通过 Transact-SQL 创建使用 Windows 身份验证的 SQL Server 登录名?在查询编辑器中,输入以下 Transact-SQL 命令: CREATE LOGIN FROM WINDOWS。 GO 通过 Transact-SQL 创建使用 SQL Server 身份验证的 SQL Server 登录名?在查询编辑器中,输入以下Transact-SQL 命令: CREAT

40、E LOGIN WITH PASSWORD = 。 GO 3.设置数据库用户创建数据库用户在 SQL Server Management Studio 中,打开对象资源管理器并展开要在其中创建新登录名的服务器实例的文件夹。依次展开数据库,某个具体数据库,“用户”右键单击用户,选择“新建用户”输入用户名,选择登录名,确定通过 Transact-SQL 创建数据库用户(create user): create user dba for login dba with default_schema=dbo 并指定数据库用户“dba”的默认schema 是“ dbo”。这意味着用户“dba” 在执行“

41、select * from t ”,实际上执行的是“select * from dbo.t ”。4 设置数据库角色新建角色在 SQL Server Management Studio 中,打开对象资源管理器并展开要在其中创建新登录名的服务器实例的文件夹。依次展开数据库,某个具体数据库,“角色”右击选中新建角色通过 Transact-SQL 新建角色: CREATE ROLE role_name 在对象资源管理器中设置数据库角色在 SQL Server Management Studio 中,打开对象资源管理器并展开要在其中创建新登录名的服务器实例的文件夹。依次展开数据库,某个具体数据库,“用户

42、”选中某用户,右击“属性”,在展开的数据库用户属性对话框中进行设置通过 Transact-SQL 设置数据库角色通 过 加 入 数 据 库 角 色 , 赋 予 数 据 库 用 户 “ dba ” 权 限 :exec sp_addrolemember db_owner, dba 此时, dba 就可以全权管理数据库 mydb 中的对象了。如果想让SQL Server 登陆帐户“ dba”访问多个数据库,比如mydb2。可以让 sa 执行下面的语句:use mydb2 go create user dba for login dba with default_schema=dbo go exec

43、sp_addrolemember db_owner, dba go 此时, dba 就可以有两个数据库 mydb, mydb2 的管理权限了!5.设置管理对象的权限在对象资源管理器中授权:选中需要授权的登录名、用户名或角色名右键单击选择“属性”,在弹出的该对象的属性窗口中选择“安全对象”,进行权限分配通过 Transact-SQL 分配权限:通过GRANT 和 REVOKE 语句精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 22 页,共 30 页23 / 30 四、实验任务1、创建角色ProgramerRole ,拥有创建表,存储过程,视图权限,

44、拥有对Salary表的查询、修改、插入权限2、创建一个登录账号Testlogin 3、创建对应于这个登录账号的数据库用户TestUser 4、将用户TestUser 添加到 TestRole 角色中五、实验报告要求1、写出与上述任务相对应的SQL 语句2、思考数据库服务器上的角色有哪些?权限类型有哪些?3、并记录在实验过程中遇到的问题、解决办法及心得体会。实验 4 触发器和存储过程实验4.1 触发器实验一、实验目的掌握触发器的创建、修改和删除操作。掌握触发器的触发执行。掌握触发器与约束的不同。二、实验要求1. 创建触发器。2. 触发器执行触发器。3. 验证约束与触发器的不同作用期。4. 删除新

45、创建的触发器。三、实验内容(一)示例1. 创建触发器启动SQL Server 查询编辑器,选择要操作数据库,如“sc(学生选课)”数据库。在查询命令窗口中输入以下CREATE TRIGGER 语句,创建触发器。为 sc( 学生选课 ) 表创建一个基于UPDATE操作和DELETE操作的复合型触发器,当修改了该表中的成绩信息或者删除了成绩记录时,触发器被激活生效,显示相关的操作信息。- 创建触发器CREATE TRIGGER tri_UPDATE_DELETE_sc ON sc FOR UPDATE,DELETE 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - -

46、 - -第 23 页,共 30 页24 / 30 AS - 检测成绩列表是否被更新IF UPDATE(成绩 ) BEGIN - 显示学号、课程号、原成绩和新成绩信息SELECT INSERTED. 课程号, DELETED. 成绩 AS原成绩,INSERTED. 成绩 AS新成绩FROM DELETED ,INSERTED WHERE DELETED.学号 =INSERTED. 学号END - 检测是更新还是删除操作ELSE IF COLUMNS_UPDATED( )=0 BEGIN - 显示被删除的学号、课程号和成绩信号SELECT 被删除的学号=DELETED. 学号, DELETED.

47、课程号,DELETED. 成绩 AS原成绩FROM DELETED END ELSE - 返回提示信息PRINT 更新了非成绩列!点击快捷工具栏上的快捷按钮,完成触发器的创建。2. 触发触发器在查询命令窗口中输入以下UPDATE sc语句,修改成绩列,激发触发器。UPDATE sc SET成绩 =成绩 +5 WHERE 课程号 =101在查询命令窗口中输入以下UPDATE sc语句修改非成绩列,激发触发器。UPDATE sc SET 课程号 =113WHERE 课程号 =103在查询命令窗口中输入以下DELETE sc 语句,删除成绩记录,激发触发器。DELETE sc WHERE 课程号 =

48、1023. 比较约束与触发器的不同作用期在查询命令窗口中输入并执行以下ALTER TABLE 语句,为sc 表添加一个约束,使得成绩只能大于等于0 且小于等于100。ALTER TABLE sc ADD CONSTRAINT CK_成绩CHECK( 成绩 =0 AND成绩 =100) 在查询命令窗口中输入并执行以下UPDATE sc语句,查看执行结果。UPDATE sc SET成绩 =120 WHERE 课程号 =108精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 24 页,共 30 页25 / 30 在查询命令窗口中输入执行以下UPDATE s

49、c语句,查看执行结果。UPDATE sc SET成绩 =90 WHERE 课程号 =108从这部分实验中,我们可以看到,约束优先于触发器起作用,它在更新前就生效,以对要更新的值进行规则检查。当检查到与现有规则冲突时,系统给出错误消息,并取消更新操作。如果检查没有问题,更新被执行,当执行完毕后,再激活触发器。4. 删除新创建的触发器在查询命令窗口中输入DROP TRIGGER 语句,删除新创建的触发器。DROP TRIGGER tri_UPDATE_DELETE_sc 点击快捷工具栏上的快捷按钮,删除触发器。(二)练习1. 在 Student表中编写 insert的触发器,假如每个班的学生不能超

50、过30 个,如果低于此数,添加可以完成;如果超过此数,则插入将不能实现。2. 在 SC表上编写update 触发器,当修改SC表中的 grade 字段时将其修改前后的信息保存在SC_log 表中。四、实验报告要求1、写出与上述任务相对应的SQL 语句2、并记录在实验过程中遇到的问题、解决办法及心得体会。4.2 存储过程实验一、实验目的掌握用户存储过程的创建操作。掌握用户存储过程的执行操作。掌握用户存储过程的删除操作。二、实验内容1、创建带输入参数的存储过程的存储过程。2、执行所创建的存储过程。3、删除所有新创建的存储过程。三、实验步骤对应于 student数据库(1) 创建一个无参存储过程St

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 技术资料 > 技术总结

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知得利文库网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号-8 |  经营许可证:黑B2-20190332号 |   黑公网安备:91230400333293403D

© 2020-2023 www.deliwenku.com 得利文库. All Rights Reserved 黑龙江转换宝科技有限公司 

黑龙江省互联网违法和不良信息举报
举报电话:0468-3380021 邮箱:hgswwxb@163.com