




已阅读5页,还剩8页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
数据库管理与维护实训指导书课程类别: 专业必修课适用对象:计算机应用专业独立实践学时:27学时一、实训内容及要求(一)实训内容:在SQL Server2005环境下,通过一个数据库系统的具体实现让学生掌握中型数据库系统的设计以及管理的基本方法。具体包括:表结构设计数据维护查询操作规则的创建和维护约束的创建和维护存储过程的创建和维护触发器的创建和维护备份实施(二)实训要求如下:学生两人一组,题目自选(难度系数为1),也可以参考教材案例(难度系数0.75)。(参考选题见指导书第六部分)要求:1、实训项目选择的系统最好将实体数量规模控制在3-5个,系统设计部分要求包含下列内容:1)系统主要功能描述;2)数据字典;3)E-R图;4)关系模式;(不要求!)5)物理表结构;6)表关系结构图。2、数据库基本表不少于3个,每个表中的测试记录不少于10条;3、练习必须涵盖(一)中的所有实训内容,具体要求如下:1) 创建一个涉及2个表的查询操作;2) 创建一个规则,并进行验证;3)创建一个约束并进行验证;4)创建一个存储过程并进行验证;5)创建一个触发器并进行验证;6)创建一个登录帐户,赋予其修改表结构的权限,并进行验证;7)进行数据库完全备份,并进行还原.(三)需提交资料实训结束时,学生需要提供完整的实训报告(电子版和纸质页)以及完整代码。其中,电子版每组提交一份,纸质版每人一份。二、实训过程(含步骤)(一)表结构设计:要求使用T-SQL命令完成数据库和表结构的创建,命令提示如下:1、创建数据库:创建Test数据库,该数据库的主数据文件逻辑名称为Test_data,物理文件名为Test.mdf,初始大小为10MB,最大尺寸为无限大,增长速度为10%;数据库的日志文件逻辑名称为Test_log,物理文件名为Test.ldf,初始大小为1MB,最大尺寸为5MB,增长速度为1MB。程序清单如下:CREATE DATABASE test ON PRIMARY ( NAME = test, FILENAME=C:Program FilesMicrosoft SQL ServerMSSQLdatatest.mdf, SIZE=10240KB, MAXSIZE = UNLIMITED,FILEGROWTH = 10%)LOG ON ( NAME=test_log,FILENAME=C:Program FilesMicrosoft SQL ServerMSSQLdatatest_log.ldf,SIZE=1024KB,MAXSIZE = 5120KB,FILEGROWTH = 1024KB )GO2、创建表及外键约束:在分销系统数据库中创建客户资料表、销售订单表和销售订单明细表,并建立外键约束。程序如下:/创建客户资料表:use 分销系统goCREATE TABLE 客户资料(客户编码 varchar(20) NOT NULL PRIMARY KEY,客户名称 varchar(100) NOT NULL,联系人 varchar(20) NOT NULL,电话 varchar(50) NOT NULL,传真 varchar(50),地址 varchar(200),送货地址 varchar(200)go/创建销售订单表并建立外键约束:USE 分销系统GOCREATE TABLE 销售订单(销售订单号 varchar(20) NOT NULL PRIMARY KEY,日期 datetime NOT NULL,客户编码 varchar(20) NOT NULL FOREIGN KEY REFERENCES 客户资料(客户编码),客户名称 varchar(100) NOT NULL,联系人 varchar(20) NOT NULL,联系电话 varchar(50) NOT NULL,送货地址 varchar(200) NOT NULL,总金额 numeric(12,4) NOT NULL,备注 varchar(500) NULL,)go/创建销售订单明细表,并建立外键约束:USE 分销系统GOCREATE TABLE 销售订单明细表(销售订单号 varchar(20) NOT NULL,序号 int IDENTITY(1,1) NOT NULL,商品编码 varchar(20) NOT NULL,商品名称 varchar(50) NOT NULL,规格型号 varchar(100) NOT NULL,单位 varchar(8) NOT NULL,数量 numeric(12, 2) NOT NULL,单价 numeric(12, 2) NOT NULL,金额 numeric(12, 2) NOT NULL,备注 varchar(500) NULL,PRIMARY KEY (销售订单号,序号),FOREIGN KEY (销售订单号) REFERENCES 销售订单(销售订单号)go(二)数据表操作和维护:要求用T-SQL命令完成表数据的添加、更改和删除。程序代码提示如下:1、插入数据:在“分销系统”库的“仓库资料”表中添加记录:use 分销系统goinsert into 仓库资料values (JK01,窖口仓库,常青路221号,易燃物)insert 仓库资料values (HP02,黄埔仓库,桥东路12号,NULL)insert 仓库资料 (仓库编码,仓库名称, 仓库位置) values (DC03,东涌仓库,新港东路241号)go2、更新数据:在SCDB库中,给全班考试不及格的学生加10分UPDATE StuScore SET Score=Score+10WHERE Score603、使用约束:用AlterTable命令为学生表Student创建CHECK约束: USE SCDB GO ALTER TABLE Student ADD CONSTRAINT CK_Student CHECK(sex= 男 or sex=女) GO 4、使用规则:创建一个规则,将其绑定到Student表的Sex列上,保证输入的性别值是0或1Create rule value_sex1 as value in (0,1)GoExec sp_bindrule value_sex1,student.sexGo (三)存储过程和触发器管理:要求应用T-SQL命令创建存储过程和触发器实现表数据的操作和维护。1、使用存储过程:创建一个存储过程,以简化对sc表的数据添加工作,使得在执行该存储过程时,其参数值作为数据添加到表中。程序清单如下:CREATE PROCEDURE dbo. pr1_sc_ins Param1 char(10),Param2 char(2),Param3 real ASBEGINinsert into sc(sno,cno,score) values(Param1,Param2,Param3)END 2、使用触发器:下面代码建立一个触发器,当向sc表中添加数据时,如果添加的数据与s表中的数据不匹配(没有对应的学号),则将此数据删除。程序清单如下:CREATE TRIGGER sc_ins ON sc FOR INSERT ASBEGINDECLARE bh char(5)Select bh=Inserted.sno from InsertedIf not exists(select sno from s where s.sno=bh)Delete sc where sno=bh END 3、下面代码创建一个触发器,当插入或更新成绩列时,该触发器检查插入的数据是否处于设定的范围内。程序清单如下:CREATE TRIGGER sc_insupd ON scFOR INSERT, UPDATEASDECLARE cj int,SELECT cj=inserted.score from insertedIF (cj 100) BEGIN RAISERROR (成绩的取值必须在0到100之间, 16, 1) ROLLBACK TRANSACTIONEND (四)查询操作:要求掌握多条件查询和多表查询的T-SQL语句.1、条件查询:查询选修C1或C2且分数大于等于85分学生的的学号、课程号和成绩。程序清单如下:SELECT SNO,CNO,SCORE FROM SCWHERE(CNO=C1 OR CNO=C2) AND SCORE=852、使用聚合函数:通过查询求学号为S1学生的总分和平均分。程序清单如下:SELECT SUM(SCORE) AS TotalScore, AVG(SCORE) AS AveScore FROM SCWHERE SNO = S13、多表查询:查询所有选课学生的学号、姓名、选课名称及成绩。程序清单如下:SELECT S.SNO,SN,CN,SCOREFROM S,C,SCWHERE S.SNO=SC.SNOAND SC.CNO=C.CNO(五)备份:要求掌握数据库各种备份的T-SQL实现方法。1、完全备份:通过命令行进行完全数据备份第一步、创建磁盘备份文件:使用系统存储过程sp_addumpdevice,其基本命令行如下所示:sp_addumpdevice devtype=device_type,logicalname=logical_name, physicalname = physical_name,cntrltype = controller_type|devstatus=device_status 注意:即便是C盘下面没有back文件夹,该命令也可以成功的执行。但是如果在实际进行磁盘备份中,由于没有该文件夹,将在执行backup database的时候出现错误。第二步、用BACKUP DATABASE执行备份。下列命令将school数据库备份到第一步建立的磁盘备份文件中:BACKUP DATABASEdatabase_name|database_name_var ,.f TO ,.n .,INIT|NOINIT注意:在进行数据库备份的时候,INIT和NOINIT选项参数非常重要:使用 NOINIT 选项,SQL Server 把备份追加到现有的备份文件,也就是在原有的数据备份基础上,继续将现有的数据库追加性的继续备份到该磁盘备份文件中。2、使用 INIT 选项,SQL Server 将重写备份媒体集上所有数据,即将上次备份的文件抹去,重新将现有的数据库文件写入到该磁盘备份文件中。 init由于重新建立磁盘备份,因此文件并没有增长;而由于noinit是追加备份,因此磁盘文件增长非常明显。可以不需要使用磁盘备份文件,而通过直接指定磁盘路径的方式实现对数据库文件进行备份:BACKUP DATABASE school TO DISK=D: Mydiffbackup.bak3、差异备份:使用命令进行差异数据备份差异备份同样使用BACKUP DATABASE命令完成,仅仅多了WITH DIFFERENTIAL参数:BACKUP DATABASE school TO DISK=D:school_back.bak WITH DIFFERENTIAL -或者: backup database school to backup_file2 WITH DIFFERENTIAL(六)撰写实训报告.三、实训报告的编写指导(一)内容格式报告包含以下内容:(1)封面填写:实训项目,班级、学号、实训日期和实训地点;(2)实训内容及要求:要有数据库基本表结构及其关系建立的说明;(3)操作步骤:每一项操作要附原代码以及结果截图;(4)实训心得与体会;(二)实训报告评分标准按照五级计分制分优、良、中、及格和不及格。具体地:优秀:严格按照实训报告编写要求编写。完成所有实训任务,实验步骤详细,按照要求提供了详细实训过程记录表。良好:能按照实训报告编写要求编写。完成所有实训任务,有比较详细实验步骤,提供了比较详细实训过程记录表。基本合格:基本按照实训报告编写要求编写。完成所有实训任务,每项实训任务均有实验步骤,提供了实训过程记录表。不合格:不按照实训报告编写要求编写。没完成实训任务,实验步骤简单,或未提供实训过程记录表。(三)考核方式、形式及成绩评定1、考核方式:考查。2、考核形式:过程考核。学生每完成一项子任务,经指导教师检查,给出成绩后,再完成下一项子任务。3、总评成绩的组成及评定标准总评成绩=考勤(20%)+实操(70%
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年新能源汽车融资租赁保理业务保证合同
- 2025年度冷链物流集装箱运输与风险管理合同
- 2025年工业厂房屋顶防水修复与定期保养技术服务合同
- 2025年金融机构财务代理服务合同样本集
- 2025年校园围栏表面环保涂装与改造工程合同
- 2025年度证券融资租赁担保合同模板与合规审查
- 2025年北京高端车牌使用权及车辆全面维护服务合同
- 2025年智能机器人制造基地厂房租赁与研发设施共享合作协议
- 2025年度智能车库租赁与车位租赁升级续约协议
- 2025年校园体育设施租赁与维护管理合作协议
- 证券行业智能化投资组合管理方案
- 银行员工消保知识培训
- 地理与劳动教育
- 第5课 甲午中日战争与列强瓜分中国狂潮 公开课一等奖创新教学设计
- 初中数学新人教版七年级上册第二章《有理数的运算》教案(2024秋)
- 人教版(2025新版)七年级下册数学第七章 相交线与平行线 单元测试卷(含答案)
- 厂房消防应急预案
- 景区开发政府战略框架协议书(2篇)
- “雄鹰杯”全国小动物医师技能大赛考试题库(660题)
- 实验室隐患排查培训
- 九年级化学第三单元课题1分子和原子人教新课标版省公开课获奖课件说课比赛一等奖课件
评论
0/150
提交评论