图书管理系统数据库课程设计的报告报告书.docx

上传人:夺命阿水 文档编号:1371690 上传时间:2024-06-14 格式:DOCX 页数:10 大小:46.72KB
返回 下载 相关 举报
图书管理系统数据库课程设计的报告报告书.docx_第1页
第1页 / 共10页
图书管理系统数据库课程设计的报告报告书.docx_第2页
第2页 / 共10页
图书管理系统数据库课程设计的报告报告书.docx_第3页
第3页 / 共10页
图书管理系统数据库课程设计的报告报告书.docx_第4页
第4页 / 共10页
图书管理系统数据库课程设计的报告报告书.docx_第5页
第5页 / 共10页
点击查看更多>>
资源描述

《图书管理系统数据库课程设计的报告报告书.docx》由会员分享,可在线阅读,更多相关《图书管理系统数据库课程设计的报告报告书.docx(10页珍藏版)》请在课桌文档上搜索。

1、图书管理系统一、背景资料:1)图书馆有各种图书假设干万册。2)每种图书都有书名、图书编号、作者译者)、出版社、定价和内容简介。3)借书证记录有借阅者的姓名、工作单位、住址、联系等。4)凭借书证借书,每次最多能借5本书,借书期限最长为60天。二、系统功能需求:1)图书馆借阅书籍于归还书籍的登记。也就是为读者建设一个台账,应用该台账,工作人员能方便地掌握某位读者借了哪些书,借了多长时间。2)编著催还图书通知单。图书馆对所借书籍的最长借阅时间限制为60天,对逾期未还的读者下达催还图书通知单,促其尽快还书,以加快图书的流通。3)提供快速的图书查询功能,方便读者尽快插大所需要的书。4)系统提供的全部功能

2、要简单、直观、实用。三、系统数据库关系的E-R图:系统所涉及到的实体及关联关系比较简单,主要的实体只有读者和图书两个,他们通过读者的借阅活动而发生联系,其ER图如下:四、系统设计:1、功能设计:1)图书借阅。为有借书证的读者办理借阅登记,登记的内容包括借书证编号、图书编号、借阅日期。2)图书归还。在适当位置登记,这个适当位置应该由借书证编号和图书编号决定。3)编制催还图书通知单。对借阅图书超过60天者打印催还图书通知单,其内容包括借书证编号、读者姓名、号码、图书编号、名称、作者、出版社、借阅日期等信息。4)借书证办理与退还。本系统只提供对借书证发放(办理)和回收(退还)两个过程的支持。5)图书

3、入库预报废。新采购书的入库登记和废旧图书的报废登记。对于新书入库有两种不同的情况:其一是新采购的图书在以前登记过,这次属于补充库存;其二是图书馆以前没有登记过。2、数据库设计:根据ER图,将其转化为如下数据实体,数据库:book.dbc,包括如下的表和视图:1)借书证发放登记表reader.dbfo借书证编号C(8)读者姓名C(8)工作单位C(30)号码C(Il)家庭住址C(20)办证日期D退证日期D图书登记表booker.dbft图书编号C(8)图书名称C(30)作者C(8)出版社C(30)图书类别C(8)图书价格N(5,l)内容提要M库存数量I在库数量I图书类型表typer.dbf图书类别

4、C(8)借书登记表brower.dbf借书证编号C(8)图书编号C(8)借阅日期D归还日期D5)借书视图brower为了打印催还通知书单的需要,设计了一个借书视图文件,该视图从reader.dbf等3个表中提取了7个字段的数据:reader.借书证编号reader.姓名reader.号码brower.图书编号brower.借阅日期booker.图书名称booker.作者其视图关系可由以下SQ1.语句定义:Selectreader.借书证编号,reader.姓名,reader.号码,brower.图书编号brower.借阅日期,booker.图书名称,booker.作者;frombook!rea

5、derinnerjoinbook!brower;innerjoinbook!booker;onbrower.图书编号=booker.图书编号onreader.借书证编号=brower.借书证编号;wherebrower.借阅日期Vdata()-60;anddata()-brower.归还日期二0;orderbyreader.借书证编号3、总体模线设计:该系统的全部功能由一个主控界面(两个表单)、一个报表以及相关的四个表单组成,其总体模块框图如下:图书馆信息管理系统借书证管理(表单)借书登记(表单)还书登记俵单)图书库存管理(表单)催还通知(报表)五、模块设计:1、欢迎界面和主控界面表单的设计:

6、图书馆信息管理系统的主界面由“欢迎表单和“主控表单组成,主控表单上安排六个命令按钮,分别实现总体框图中的五局部功能和退出系统模块。每个命令按钮触发的结果均执行一条命令,运行个表单,或启动一个报表文件的运行,或者退回到ViSUaIfOXPro系统状态。欢迎表单标签的CaPtion属性为“欢迎使用河南理工大学图书管理系统!,并设置“进入和“退出两个按钮,通过“进入按钮(设计代码为:doform主控表单.sex)进入主控界面,通过“退出按钮退出系统。主控表单的设计代码如下:“借书证管理按钮的CliCk事件代码:doform借书证管理.sex“借书登记按钮的CliCk事件代码:doform借书登记.s

7、cx“还书登记按钮的CliCk事件代码:doform还书登记.scx”图书入库与报废按钮的click事件代码:doform图书入库与报废.sex“催还书通知按钮的click事件代码:reportform催还书通知.frx“退出系统按钮的CliCk事件代码:Releasethisfo11nCloseallQuit2、其他表单的设计:1)借书证管理表单设计:此表单的数据源是reader.dbf表,在其支持下完成用户要进展的图书证的发放和退回工作。用户从“借书证编号文本框中输入一个借书证编号,如果该借书证在reader.dbf表中已存在,系统会在下面的表格对象中显示与之对应的读者情况,否那么显示为空

8、。当单击“办理借书证按钮后,系统会在表格中添加一行空记录,等待用户输入新读者的资料,并自动把办证日期赋值为系统当前日期,用户退出表单时系统将新数据存入与表单对应的reader.dbf表中;当用户单击“退还借书证按钮后,系统把当前日期赋值给换证日期字段,表述该读者已归还借书证。与表单对应的各种对象的属性值和事件代码说明如下:(1) “借书证编号文本框的属性值和事件代码:Name属性textlFormatJSttXXXXXXXXXXInteractivechange事件代码:thisfbrm.dataenvironment.cursor1.fHter=借书证编号=+trim(this.value)

9、+thisfbrm.refreshreturn1.ostfocus事件代码:thisfo11n.dataenvironment.cursor1.fHter=借书证编号=+trim(this.value)+”thisfbrm.refreshreturn(2) “办理借书证按钮的CliCk事件代码:appendblankreplace借书证编号WiththiSfOnn.text1.value,办证日期withdate()thisform.dataenvironment.cursor1.filter=,借书证编号=,+M+trim(thisform.textl.value)+,H,thisfbrm.

10、refreshreturn(3) “退还借书证按钮的CliCk事件代码:thisfbrm.gird1.column6.text1.value=data()return(4)“退出按钮的CliCk事件代码:C1.OSEA1.1.Thisfbrm.release其他表单的“退出按钮的代码完全一样,以后不再进展说明。2)借书证登记表单的设计:此表单是整个系统的一个主要菜单,共涉及到reader.dbf,booker.dbf,brower.dbf,typer.dbf等四个表。用户在左上角的组合框对象中选择“借书证编号,文本框中的“读者姓名与“号码是系统自动显示的。在“选择图类型组合框中选择要借阅的图类

11、型,表格中显示图书的库存信息,在单击“借阅按钮后,系统自动进展借阅登记,表单下半局部显示该读者现在未归还的图书及借阅日期。下面对有关对象的属性及代码进展说明:(1) 数据环境。数据环境中包含了四个表,其中的CUOSOr对象与表的对图书类型表图书登记表借书证登记表借书登记表应关系如下:Cuosorl一typer.dbfCuosor2-booker.dbfCuosor3-reader.dbfCuosor4brower.dbf(2) “借书证编号组合框的属性和事件代码:Constrolsource属性reader.借书证编号Interactivechange代码:thisfb11n.dataenvi

12、ronment.cursor3.filter=借书证编号二+this,value+”thisform.dataenvironment.cursor4.f11ter=借书证编号二this.value+,+,anddata()-brower.归还日期二0,thisfbrm.refreshIostfocus代码:thisform.dataenvironment.cursor3.filterT借书证编号=+this.value+”thisform.dataenvironment.cursor4.filter=彳昔书证编号this.value+,anddata()-brower.归还日期二0,thisf

13、brm.refresh(3) “图书类型选择组合的属性:Rowsource属性typer.图书类别(4)显示姓名的文末框:Controlsourcereader.读者姓名(5)显示号码的文本:Controlsourcereader.号码(6)表单上半局部的表格对象,由表格对象生成器生成即可,该表格对象以booker.dbf表为数据源。(7)表单下半局部的表格对象,由表格对象生成器生成即可,该表格对象以brower.dbf表为数据源。(8)“借书按钮的CIiCk事件代码如下:ifbooker.图书编号=trim(thisformbo2.value)replacebooker.在库数量withbo

14、oker.在库数量-1endififused(brower)selectbrowergobottomappendblankendififbooker.图书编号=trim(thisformbo2.value)replacebrower.图书编号withbooker.图书编号replacebrower.借阅日期withdata()endififused(reader)selectreaderreplacebrower.借书证编号withreader.借书证编号endifthisfrm.refreshreturn3)还书登记表单的设计:该表单共涉及reader.dbf,brower.dbf和book

15、er.dbf等三个数据表,当用户在借书证编号的组合框内选择一个借书证编号后,系统会自动在后面的文本框中现实与该编号对应的读者姓名和联系,并在表格对象中显示该读者尚未归还的书,然后由用户在表格中用鼠标选择其要归还的书,选中后单击“还书按钮。有关对象的属性及代码说明如下:(1)数据环境。该数据环境包含三个表,数据环境中CUrSor对象与表的对应关系是:Cursorlreader.dbfCursor2brower.dbfCursor3booker.dbf(2) “借书证编号组合框的属性和事件代码:Rowsource属性reader.借书证编号Gotfocus事件代码:Thisfbrm.dataenv

16、ironment.cursorl.filter=n,thisfbrm.refreshInteractivechange代码:thisfbrm.dataenvironment.curSOr1.fnter=借书证编号=+this,value+”thisfbrm.dataenvironment.cursor2.f11ter=借书证编号=+this.value+anddata()-归还日期=0thisform.refresh(3)读者姓名文本框属性。Control属性reader.读者姓名Enable属性.E4)读者文本框属性。Control属性reader.号码Enable属性.E(5)表格对象。表

17、格对象由表格生成器生成,数据源为brower.Dbf表,并在生成后表格的列对象的enabled属性设为.F.(6)“还书按钮的CIiCk事件代码:tdbf=alias()select(thisfbrm.dataenvironment.cursor2.alias)replace归还日期withdata()select(thisfbrm.dataenvironment.cursor3.alias)replace在库数量with在库数量+1select&tdbfthisfbrm.refreshreturn(4) “图书入库与报废表单的设计:该表单左上角的“图书编号文本框供用户输入要登记入库和要报废的

18、图书编号,后面的册数文本框输入对应的或报废的图书册数,如果所输入的图书编号是一个booker.dbf表中已存在的编号(这表示是进展图书报废登记),下面的表格对象中会显示该图书的其他信息,反之,表示一种新书要入库登记,实质是要将这种图书信息添加到booker.dbf数据表中。对表单中有关对象的属性与代码说明如下:(1)数据环境。表单中只包含一个booker.dbf表。(2)“图书编号与“册数文本框。Name属性分别为textl和text20(3)表格对象,由表格生成器生成。(5) “新书入库登记按钮CliCk事件代码:thisfbrm.dataenvironment.cursor1.filter

19、=图书编号-+trim(thisform.text1.value)+,n,ifeof()appendblankreplace图书编号withthisform.text.valuethisform.refreshthisfrm.grid!.column1.enable=.t.thisfbrm.grid1.column2.enable=.t.thisfbrm.grid1.column3.enable=.t.thisfbrm.grid1.column4.enable=.t.thisfbrm.grid1.column5.enable=.t.endifthisfbrm.grid1.column8.tex

20、t1.value=thisform.grid1.column8.text1.value+val(thisform.text2.value)thisfbrm.grid1.column9.text1.value=thisform.grid1.column9.text1.value+val(thisform.text2.value)thisfbrm.refreshreturn(6) “图书报废登记按钮的CIiCk事件代码:thisfbrm.grid1.column8.text1.value=thisform.grid1.column8.text1.value-val(thisform.text2.v

21、alue)thisfbrm.grid1.column9.text1.value=thisform.grid1.column9.text1.value-val(thisform.text2.value)thisfbrm.refreshreturn3、“催还图书通知报表设计:“催还图书通知报表的设计过程说明如下:报表数据源brower.vue视图,该视图已在前面做了说明。报表分组条件reader.读者姓名报表排序条件reader.借书证编号该报表由向导程序生成,其后进展了一些格式美化的调整修改工作,关键问题是要先定义好作为数据源的试图文件。六、总结:任何一个社会组织和企业公司在开展过程中都会产生大

22、量的数据,这些数据的组织存储、分析统计有利于提高企业的开展,有利于提高企业的效率。这些数据的组织和存储就是数据模型,就是数据库应用系统开发的任务。数据库应用系统开发的过程一般包括可行性研究、需求分析、系统设计、程序编码、程序调试和系统维护六个阶段。根据数据库应用系统的复杂程度,不一定完全刻板地遵守上述步骤,但是,可行性研究、需求分析、系统设计、程序编码、程序调试是不可缺少的。本次课程设计制作了一个简单的图书馆管理系统,实现了一些图书管理和借阅功能,但与实际系统还是有很大差异的。首先是对应用情况做了简单的理想化处理,因而难以反映实际工作中可能遇到的实际问题;其次,未考虑用户操作中可能出现的错误的处理,而实际上这种错误的处理程序可能占应用系统的很大一局部。如本系统在需求分析和程序健全性方面均存在一些问题,为了解决这些不完善之处,需要在今后的进一步学习中,逐步深入,不断积累经历,不但提高。

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

当前位置:首页 > 在线阅读 > 生活休闲


备案号:宁ICP备20000045号-1

经营许可证:宁B2-20210002

宁公网安备 64010402000986号