ImageVerifierCode 换一换
格式:DOCX , 页数:19 ,大小:122.04KB ,
资源ID:7149573      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bingdoc.com/d-7149573.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(数据库大作业全参考答案文档格式.docx)为本站会员(b****3)主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(发送邮件至service@bingdoc.com或直接QQ联系客服),我们立即给予删除!

数据库大作业全参考答案文档格式.docx

1、阅览室有两个人。我们俩都有一台计算机,最好两台计算机都可以用上这个软件。 1.2 需求分析1)功能需求图1-1:功能需求示意图教师信息管理:用于教师基本资料的增删改查。图书信息管理:用于图书基本信息的增删改查,分类统计图书册数和价值。借书登记:记录借书时间、所借图书、借书人、办理人。还书登记:记录还书时间、所还图书、还书人、办理人。催还:查询借阅逾期的借书信息,给借书人发电子邮件,给借书人的部门打电话。2)运行环境要求图1-2:运行环境拓扑图系统采用C/S模式,有两台PC和一台服务器,联成一个局域网。PC上安装图书管理软件的客户端,服务器上安装DBMS,服务器也可由两台PC中的一台来代替。第二

2、部分 作业1E-R模型与关系模型设计(满分8分)本部分的任务是:在需求分析的基础上,进行E-R图设计,然后将E-R模型转换为关系模型。任务:1)根据需求描述,绘制E-R图。2)将E-R图转换成关系模型,写出所有的关系模式,并写出每一个关系是按照什么规则转换而成的。3)在已经形成的关系模型下,举例说明连接运算、投影运算、选择运算。参考答案:(属性写在了实体和联系图形内)1)根据需求描述,分别为“图书管理系统”的不同功能模块绘制局部E-R图。图书基本信息管理:借还书登记:催还书登记:2)整体E-R图3)关系模式类型表(类型名,借阅期限),依据:实体转换为关系。图书表(ISBN,书名,作者,出版社,

3、出版时间,单价,类型名,状态),依据:实体转换为关系,1:N的联系合并到N,在N方增加一个外键: 类型名。注:状态属性为(库存,借出)管理员表(管理员名,性别,口令) ,依据:教师表(教师工号,姓名,性别,Email,部门名), 部门名。部门表(部门名,电话),依据:借还表(借还业务编号,ISBN,教师工号,借办理人,借出日期,还办理人,归还日期),M:N联系转换为一个关系,取联系的实体的键加联系属性作为其属性,可以增加一个列作为主键。催还表(催还业务编号,ISBN,教师工号,办理人,催还日期),4)在已经形成的关系模型下,举例说明连接运算、投影运算、选择运算。连接运算:查看类型的图书已经超过

4、了有效借出期限。(需要图书,类型,借还关系)投影运算:查看图书的书名、作者。选择运算:查看单价高于50元的图书。3 作业2用SQL语句建库建表、增删改查数据、创建视图1)根据关系规范化的要求,在第一部分得到的图书管理系统关系模式需要进行规范化吗?如果需要,请写出写出符合3NF的关系模式。2)在得到3NF的图书管理系统关系模式的基础上,将每个关系转换为SQL Server支持的表结构,用表格形式表示出表结构。类型表列名类型约束类型名NChar(10)Pk借阅期限TinyintNot null图书表ISBNChar(20)书名Nchar(10)作者Nchar(4)出版社出版时间Datetime单价

5、MoneyFK references类型表(类型名)状态NChar(2)检查约束管理员表管理员名性别Nchar(1)口令部门表部门名PK电话char(11)教师表教师工号Char(10)姓名Emailchar(20)FK references 部门表(部门名)借还表借还业务编号IntFK references 图书表(ISBN)Fk references教师表(教师工号)借办代理人借出日期还办代理人归还日期催还表催还业务编号FK references图书表(ISBN)FK references教师表(教师工号)办代理人 null催还日期使用SQL语句,创建数据库,数据库名为BookStore,

6、在数据库中创建表,设定表的主键约束、外键约束、检查约束、默认约束、非空约束、唯一约束。写出SQL。create database BookStorecreate table 类型表( 类型名 nchar(10) not null primary key,借阅期限 tinyint not null)create table 图书表(ISBN char(20) primary key,书名 nchar(10) not null,作者 nchar(4)not null,出版社 nchar(10)not null,出版时间 datetime,单价 money not null,类型名 nchar(10

7、) not null foreign key references 类型表(类型名) on delete no action on update cascade,状态 nchar(2) not null check(状态=库存or 状态=借出create table 管理员表(管理员名 nchar(4) primary key,性别 nchar(1) check(性别=男 or 性别=女),口令 nchar(10) not nullcreate table 部门表(部门名 nchar(10) primary key,电话 char(11) not nullcreate table 教师表(教师

8、工号 char(10) primary key,姓名 nchar(4) not null,Email char(20) not null,部门名 nchar(10) not null foreign key references 部门表(部门名) on delete no action on update cascadecreate table 借还表(借还业务编号 int primary key,ISBN char(20) foreign key references 图书表(ISBN) on delete no action on update cascade,教师工号 char(10)

9、foreign key references 教师表(教师工号) on delete no action on update cascade,借办代理人 nchar(4) not null,借出日期 datetime not null,还办代理人 nchar(4) null,归还日期 datetime nullcreate table 催还表(催还业务编号 int primary key identity(1,1),办代理人 nchar(4) null,催还日期 datetime null写以下增删改查操作的SQL语句1、输入图书类型数据insert into 类型表(类型名,借阅期限)val

10、ues(文学,15), (教学参考书,180),(音乐,45)2、增加三个教师信息insert into 部门表(部门名,电话)基础部,139*电子系136*音乐艺术学院186*insert into 教师表(教师工号,姓名,性别,Email,部门名)0001张三3330002李四44440003王五555553、增加五本书的信息insert into 图书表(ISBN,书名,作者,出版社,出版时间,单价,类型名,状态)9787533954109夜航船, 张岱浙江文艺出版社2018.8.8,99.8,文学 略4、某教师今天借了某书,涉及两个操作,一是将书的状态改为“借出”,二是增加一个借书记录

11、update 图书表set 状态=where 书名=insert into 借还表(借还业务编号,ISBN,教师工号,借办代理人,借出日期)31232019.5.235、将某书的作者改为自己的姓名set 作者=*6、查询某教师的借还书记录select *from 借还表where 教师工号=7、查询某本书的流转记录where ISBN=创建视图,写出SQL语句8、借出图书视图create view 借出图书asfrom 图书表where 状态=9、借阅逾期视图create view 借阅逾期select 借还表.借办代理人,借还表.教师工号,图书表.书名from 图书表 inner join

12、借还表 on 图书表.ISBN=借还表.ISBN inner join 类型表 on 图书表.类型名=类型表.类型名where 图书表.状态= and datediff(day,借还表.借出日期,getdate()类型表.借阅期限10、图书分类统计册数视图create view 分类统计select count(*) as 书籍册数,类型名group by 类型名4 作业3存储过程与触发器设计任务1)为BookStore数据库增加一个用户oper1,允许oper1对图书表和借还表进行修改操作。 use BookStoregoexec sp_addlogin operl,(此处为密码)BookS

13、toreexec sp_addrolemember db_datareaderoperlgrant update on 图书表 to operlgrant update on 借还表 to operl2)设计存储过程a)数据初始化过程sp_Init。包含的操作有:所有的用于测试图书信息、教师信息、历史记录清空,输入图书分类、输入管理员信息、输入借书规定。略,界面进行输入或者代码输入作业用数据b)某教师在某时间借了某本书,由某管理员办理。 create procedure proc_lendbookaid char(10),atime datetime,ISBN char(20),aname n

14、char(4)beginwhere ISBN=ISBNinsert into 借还表(ISBN,教师工号,借办代理人,借出日期)values(ISBN,aid,aname,atime)endc)某教师在某时间还了某本书,由某管理员办理 create procedure proc_returnbookbid char(10),btime datetime,bname nchar(4)update 借还表set 还办代理人=bname,归还日期=btimewhere 教师工号=bid and ISBN=ISBNd)查看某人的全部借还书记录 create procedure proc_getRead

15、erlogcname nchar(4),cid char(10)select b.姓名,c.书名,a.借出日期,归还日期from 借还表 a join 教师表 b on a.教师工号=b.教师工号 join 图书表 c on a.ISBN=c.ISBNwhere b.姓名=cname or b.教师工号=cide)查看某本书的历史流转记录 create procedure proc_getBooklogbookname nchar(10),ISBN char(20)select 教师表.姓名,图书表.书名,借还表.借出日期,归还日期where a.ISBN=ISBN or c.书名=bookn

16、amef)某管理员在某时间给全部借阅过期者发催还邮件。 部分有错误的需要将修改催还业务编号为自增长(identity(1,1),还有整个表都要允许空值:例:alter table 催还表alter column 办代理人 char(4) null create procedure proc_writeEmailLogdname char(4),dtime datetimeinsert into 催还表(教师工号)select 教师工号from 借还表 a join 图书表 b on a.ISBN=b.ISBN join 类型表 c on b.类型名=c.类型名where datediff(day, a.借出日期,getdate()c.借阅期限 and a.归还日期 is nullupdate 催还表set 办代理人=dname,催还日期=dtimewhere 催还日期 is nullend g)对书名进行模糊搜索(搜索条件可以是多个模糊列值的组合,例如:搜索书名包含“网络”两个字,并且是近3年出版的图书) create procedure proc_searchmax tinyintwhere datediff(year,出版时间,getdate()rollback .

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2