数据库课程设计教材购销系统.doc

上传人:laozhun 文档编号:2395701 上传时间:2023-02-17 格式:DOC 页数:16 大小:331KB
返回 下载 相关 举报
数据库课程设计教材购销系统.doc_第1页
第1页 / 共16页
数据库课程设计教材购销系统.doc_第2页
第2页 / 共16页
数据库课程设计教材购销系统.doc_第3页
第3页 / 共16页
数据库课程设计教材购销系统.doc_第4页
第4页 / 共16页
数据库课程设计教材购销系统.doc_第5页
第5页 / 共16页
点击查看更多>>
资源描述

《数据库课程设计教材购销系统.doc》由会员分享,可在线阅读,更多相关《数据库课程设计教材购销系统.doc(16页珍藏版)》请在三一办公上搜索。

1、课程设计 教材购销系统目录1 设计时间32 设计目的33 设计任务34 设计内容34.1需求分析34.2系统设计54.2.1 概念结构设计54.2.2 逻辑结构设计74.2.3 物理结构设计84.3系统实施94.3.1数据库实现94.3.2 数据载入114.4运行与测试124.4.1运行与测试124.4.2分析155 总结与展望15参考文献161 设计时间 2 设计目的数据库原理及应用课程设计是软件工程专业集中实践性环节之一,是学习完数据库原理及应用课程后进行的一次全面的综合练习。其目的在于加深对数据库基础理论和基本知识的理解,掌握使用数据库进行软件设计的基本方法,提高运用数据库解决实际问题的

2、能力,最终实现对于给定的应用环境,构造最优的数据库模式,建立数据库及其应用系统,使之能够有效地存储数据,满足各种用户的应用需求(信息要求和处理要求)。同时,此次设计对于同学将来的毕业设计和具体工作实践将有重要的意义。3 设计任务通过数据库原理及应用这门课的学习,掌握使用数据库进行软件设计的基本方法,提高运用数据库解决实际问题的能力,最终实现对于给定的应用环境,构造最优的数据库模式,建立数据库及其应用系统,使之能够有效地存储数据,从而来完成一个教材购销管理系统,并使其具有比较完善的管理与使用功能。4 设计内容 4.1需求分析 教材购销管理系统: 教材购销管理系统是帮助管理人员、教材销售和库存的管

3、理软件。该教材购销管理系统软件目前已有比较完善的管理与使用功能,该项目的用户是学校,开发本系统是为了教材购销管理系统更完善,为了教材购销对商品库存和销售的管理更方便,为了减轻工作人员的工作负担,以现代化的创新思维模式去工作。系统的功能要求:销售子系统(1)审查有效性学生将购书单交给教材科秘书,秘书通过查阅各班学生用书表、售书登记表检查是否允许该生买书。(2)开发票如果允许学生买书,教材科会计将按购书单查阅教材存量表,如果有书且数量够,则开交款发票,否则,将购书单中无法购买的书的信息写入缺书登记表,以备以后补售教材。(3)登记并开领书单教材科出纳员根据发票上的总金额收取现金,并进行售书登记,同时

4、开领书单,学生将领书单交给保管员,领书。(4)补售教材采购部门进书后,教材科秘书根据进书通知和缺书登记表给没买到教材的学生发补售通知单。采购子系统(1)教材入库采购员采购教材后,将进书单交给秘书,秘书修改教材库存和待购量。(2)统计秘书每月按书号和出版社统计缺书,形成待购教材表和缺书单,供采购员采购时使用。教材保管员学生写购书单领书单,发票购买够查阅数量不够交购书单检查是否允许购买是教材出纳员教材科秘书否采购员4.2系统设计4.2.1 概念结构设计E-R图是分为两部分实体和属性,每个实体可以有多个属性,这些属性用来表示实体的性质。不同实体之间可以用关系进行连接,表明各个实体之间的内在联系。实体

5、和实体之间的关系有一对一的关系(1:1),一对多的关系(1:N)和多对多的关系(N:M)。各个实体分E-R图如下图所示实体:教材,学生,购书单,教材库出版社书名书号单价购书单图1-1教材E-R图性别姓名班级学号年龄学生专业图1-2学生E-R图购书人书号购书单号购买数量购书单图1-3购书单E-R图图书管理员书号库号库存量教材库图1-4教材库E-R图出版社名shehao地址出版社号电话出版社图1-2出版社E-R图总体E-R图及各个实体之间的关系如下图所示交纳书费教材库学生1书库书库填写1n对应购书单nmn买教材教材购书单细节图2-1 教材购销管理ER图4.2.2 逻辑结构设计E-R图向关系模型的转

6、换关系模型的逻辑结构是一组关系模式的集合。E-R图则是由实体,实体的属性和实体间的联系三个要素组成。所以将E-R图转换为关系模型实际上就是要将实体,实体的属性和实体间的联系转换为关系模式。转换原则如下。1. 实体类型的转换:一个实体型转换成一个关系模式。实体的属性就是关系的属性,实体的码就是关系的码。2联系类型的转换,根据不同的情况做不同的处理。 一个1:1的联系可以转换为一个独立的关系模式,也可以与任意一端对应的关系模式合并。如果转换为一个独立的关系模式,则与该联系相连的各实体的码以及联系本身的属性均转换为关系的属性,每个实体的码均是该关系的候选码。如果与某一端实体对应的关系模式合并,则需要

7、在该关系模式的属性中加入另一个关系模式的码和联系本身的属性。 一个:N的联系可以转换为一个独立的关系模式,也可以与N端对应的关系模式合并。如果转换为一个独立的关系模式,则与该联系相连的各实体的码以及联系本身的属性均转换为关系的属性,而关系的码为N端实体的码。 一个M:N联系转换为一个关系模式。与该联系相连的各实体的码为各实体码的组合。 三个或三个以上实体间的一个多元联系可以转换为一个关系模式。与该多元联系相连的各实体的码以及联系本身的属性均转换为关系的属性,而关系的码为各实体码的组合。 具有相同码的关系模式可合并。3. 根据销售信息管理系统的E-R图转换为关系模型如下。将每一个实体转换成一个关

8、系(关系就是给出关系名,属性就是实体属性,并标明该关系的主键用下划线来表示)关系模式:学生(学号,姓名,性别,年龄,所在系,班级),主码为学号,符合三范式。购书单(购书单号,书号,购买数量,购书人学号),主码为购书单号,符合三范式。教材库(图书管理员,库号,书号,库存量)主键为图书管理员,库号符,合三范式。教材(书号,书名,单价,出版社)主码为书号,符合三范式。4.2.3 物理结构设计表3-1 学生表Student字段名称中文名称类型长度取值范围是否非空主关键字备注Sno学号char 10NY外码Sname姓名char 30NNSsex性别char 10男、女NNSage年龄char 1018

9、28NNSdept专业char 10NNSclass班级char 10NN表3-2 购书单表BuyBook字段名称中文名称类型长度取值范围是否非空主关键字备注BBno购书单号char 1000009999NYBno书号char 1000009999NN外码BBamount购买数量int 10NNSno购书人学号char 10NN外码表3-3教材库表StackRoom字段名称中文名称类型长度取值范围是否非空主关键字备注SRmanager图书管理员char 1000009999NYSRno库号char 1000009999NNBno书号char 1000009999NN外码SRamount库存量i

10、nt 10NN表3-4 教材表Book字段名称中文名称类型长度取值范围是否非空主关键字备注Bno书号char 1000009999NY外码Bname书名char 30NNBprice单价char 10NNPno出版社号char 1000009999NN表3-5 出版社表Publish字段名称中文名称类型长度取值范围是否非空主关键字备注Pno出版社号char 1000009999NY外码Pname出版社名char 30NNPphone电话char 30NNPadd地址char 30NN4.3系统实施4.3.1数据库实现创建数据库:create database 教材购销创建基本表:(1)学生表:

11、学号,姓名,性别,年龄,所在系,班级create table Student(Sno char (10) primary key not null, Sname char (30) not null, Ssex char (10) not null, Sage char (10) not null, Sdept char (10) not null, Sclass char (10) not null, foreign key Sno references BuyBook(Sno)(2)购书单表:购书单号,书号,购买数量,购书人学号create table BuyBook(BBno char

12、(10) primary key not null, Bno char (10) not null, BBamount int(10) not null,Sno char (10) not null,foreign key Sno references Student(Sno),foreign key Bno references Book(Bno)(3)教材库表:图书管理员,库号,书号,库存量create table StackRoom(SRmanager char (10) not null, SRno char (10) not null,Bno char (10) not null,S

13、Ramount int(10) not null,primary key (SRno, SRmanager),foreign key Bno references Book(Bno)(4)教材表:书号,书名,单价,出版社create table Book(Bno char (10) primary key not null, Bname char (30) not null, Bprice char (10) not null, Pno char (10) not null,foreign key Pno references Public(Pno)(5)出版社表:create table P

14、ublic (Pno char (10) primary key not null, Pname char (30) not null, Pphone char (30) not null, Padd char (30) not null,)4.3.2 数据载入图4-1 学生表数据图4-2 购书单表数据图4-3教材库表数据图4-4教材表数据图4-5出版社表数据4.4运行与测试4.4.1运行与测试(1)各班学生用书表:班级、书号、书名、购买数量 select distinct Sclass,Book.Bno,Bname,BBamountfrom Student,BuyBook,Bookwhere

15、 BuyBook.Sno=Student.Sno and BuyBook.Bno=Book.Bno图5-1各班学生用书表(2)售书登记表:学号、姓名、书号、购买数量select Student.Sno,Sname,Bno,BBamountfrom Student,BuyBookwhere BuyBook.Sno=Student.Sno图5-2售书登记表(3)缺书登记表:学号、姓名、书号、缺书数量select Student.Sno,Student.Sname,BuyBook.Bno,BBamount-SRamount amountfrom Student,BuyBook,StackRoom,B

16、ookwhere BuyBook.Sno=Student.Sno andBuyBook.Bno=StackRoom.Bno andBook.Bno=BuyBook.Bno and BuyBook.BBamountStackRoom.SRamount图5-2缺书登记表(4)教材存量表:书号、单价、库存量select Book.Bno,Bprice,SRamountfrom Book,StackRoom,BuyBookwhere Book.Bno=StackRoom.Bno andBook.Bno=BuyBook.Bno图5-4教材存量表(5)待购教材表:书号、缺书数量select BuyBook

17、.Bno,BBamount-SRamount amountfrom BuyBook,StackRoomwhere BuyBook.Bno=StackRoom.Bno andBuyBook.BBamount StackRoom.SRamount图5-5待购教材表(6)缺书单:书号、缺书数量、出版社、地址、电话select BuyBook.Bno, BBamount-SRamount amount, Publish.Pno,Padd,Pphonefrom Student,BuyBook,StackRoom,Publish,Bookwhere BuyBook.Sno=Student.Sno andB

18、uyBook.Bno=StackRoom.Bno andBuyBook.Bno=Book.Bno andBook.Pno=Publish.Pno andBuyBook.BBamount StackRoom.SRamount图5-6缺书单(7)教材一览表:书号、书名、出版社、电话select Bno,Bname, Pname,Padd,Pphonefrom Book,Publishwhere Book.Pno=Publish.Pno图5-2教材一览表4.4.2分析(1)在创建基本表BuyBook和StackRoom时分别把属性.BBamount和StackRoom的类型设置成了char型,导致在

19、后面查询BBamount-SRamount的差值时这一属性时无法计算,应该将BBamount和StackRoom的类型都设置成int型。(2)在用SQL语句select BBamount-SRamount查询BBamount与SRamount两列的差值时这一属性时无法显示属性名,应将BBamount-SRamount改为BBamount-SRamount amount则amount即为BBamount与SRamount两列的差值这一属性的列名。5 总结与展望通过本次课程设计使我受益匪浅,对课堂上所学的知识有了进一步的巩固加深,并且学到了很多书本上课堂上无法学到的东西。本次课程设计锻炼了我各个方

20、面的能力,对数据库有了更深的理解,让我学会了如何用课堂上所学的知识与实际联系起来 ,使我更灵活的运用数据库的各项功能,加深了我对SQL语句的熟识度和理解度,为以后奠定了良好的基础。回顾系统的开发与论文撰写过程,有很多收获,但也有很多不尽人意之处,同时也认识到了自身的不足,促使我必须继续努力做一名优秀的软件工程师。参考文献1 萨师煊,王珊.数据库系统概论M.北京:高等教育出版社,20052 王珊.数据组织与管理M.北京:经济科学出版社,1996. 3 王能斌.数据库系统M.北京:电子工业出版社,1995. 4 李石山,盖淑华.信息系统开发中的数据库设计J.辽宁工程技术大学学报,2000,19(1):65-67. 5 张龙祥.数据库原理与设计M.成都:西南交通大学出版社,1994. 6 刘韶涛,余金山.考试系统的功能模块设计与实现J.华侨大学学报(自然科学版),2008,29(3):479-480. 成绩评定成绩 教师签字

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 建筑/施工/环境 > 项目建议


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号