1、数据库系统概论课程设计报告书图书馆管理信息系统第一步:需求分析1. 功能需求分析图书管理 用于添加、修改、删除、查询图书信息读者管理 用于添加、删除、更新、查询学生信息外借-归还图书 用于记录学生信息、图书信息、外借时间和归还时间图书分类 对图书的类型进行分类读者分类 对读者的类型分类用户管理 对使用系统的用户进行管理心得体会:我们选择了图书管理作为我们设计的数据库课程,之所以选择它是因为我们对其他方面应用的工作过程还不太了解。图书管理包括借书、还书、图书的入库、出库、图书查询等过程。我们所设计的数据库包含了以上所有功能。更进一步,我们还可以改进设计使图书管理过程完全达到无人化操作,这样不仅节
2、约了大量人力物力。还使图书管理过程更简洁方便。但由于所需要的一些技术现在还无法很好地实现,所以这也还仅仅是一个设想。2. 数据需求分析3. 我们在这里创建六个基本表,分别是booksInfo 图书信息表 ,readers 读者信息表borrowInfo 外借-归还图书表bookType 图书类型信息表readersType 读者类型信息表employees 图书管理员信息表心得体会:在数据需求分析阶段,需要设计好数据库运行时所需数据的模型,数据间的关系以及数据成员之间的数据冗余,尽量做到可以保障数据的安全性及误操作的可恢复性,要保证数据在插入、删除时不发生异常。我们所设计的几个数据表包括图书信
3、息表、读者信息表、外借-归还图书表、图书类型信息表、读者信息类型表、图书管理员信息表。在设计时考虑到了数据冗余所带来的数据插入、删除异常情况,但由于操作而进行的恢复数据却设计不周。3.数据流图 源点/终点:图书管理员、学生数据流:图书信息(图书编号,图书名称,图书类型,作者,出版社,出版日期,总页数,内容简介,总数量,进库日期,图书备注)读者信息(读者编号,读者姓名,读者性别,读者类型,读者系别,读者备注)事务(图书编号,事务类型借/还,数量)记录信息(图书信息、读者信息和日期 )更新信息(图书信息、读者信息与日期)数据存储:图书信息表,读者信息表外借-归还图书表图书类型信息表读者类型信息表图
4、书管理员信息表心得体会:一定要将数据流图与流程图中用箭头表示的控制流分清楚,否则会造成混乱画不出正确的数据流图数据流图主要描述做什么,而非怎么做,如考虑具体细节,会造成数据流图的过渡繁琐,达不到数据流图的功能遵循类似结构化程序设计方法:自顶向下,逐步求精的原则,可更好地完成此项任务,但要注意当进一步分解涉及如何具体实现一个功能时就不应再分解了4.系统数据字典 booksInfo 表其中 bookId 为主码。 bookType 表其中主码为(typeNo,typeName ) borrowInfo 表其中主码为 borrowNo,bookId 是 bookInfo 的外码,readerId 是
5、 readers 表的外码 employees 表其中主码为 userId readers 表其中主码为 readerNo readertype 表其中主码为 typeName第二步:E-R 图 心得体会:本次课程设计实习,我主要负责概念设计,并画好概念设计的主要表达E-R 图。概念结构设计图主要描述了图书管理信息系统的实体及其属性和实体之间的关系。实体指得是图书和读者以及图书管理员。它们之间的关系有,读者与图书之间的借还关系,图书管理员与图书之间的维护关系。而读者与图书及图书管理员的属性我们从数据流图可以轻松得到。总的来说,从这次实习中我学到的更多的是如何进行团队合作,真正认识到团队合作问题
6、的重要性以及团队合作能带来的巨大的共同喜悦和成功的感受。其次,从画 E-R 图的过程中,也认识到自己的一些不足之处,故而在不断的翻阅书籍处理问题的过程中有了一丝进步。第三步:系统地功能模块图 学生学号学生姓名地址图书名称图书类型出版年份读者 图书数量借还日期借还图书图书管理员学生性别读者类型读者信息内容关键字进库日期图书数目图书作者信息记录维护出版公司主窗体登录界面主菜单密码错误成功登陆图书馆职工管理 书籍管理 借阅信息管理 帮助添加用户修改密码书籍类型管理书籍信息管理借书借还综合管理还书关于 用户帮助注:最底层的 xx 管理下的功能都是:添加、更新、删除、查询主要模块的实现代码由于这个 MI
7、S 系统是用 vb 通过相应的控件对数据库(Access)的插入、更新、删除、查询操作。所以,我不想按模块给出实现代码,而是给出怎么从连接、操纵、关闭数据库的核心代码。程序中需要另外引入的控件有:Microsoft ADO Data Control 6.0 (SP6) (OLEDB)Microsoft DataGrid Control 6.0 (SP6) (OLEDB)1、 连接数据库在一个窗体上引入 ADODC 控件,然后可以直接通过更改该控件的属性连接数据库,也可以在加载窗体时给该 adodc 控件的属性赋值来完成。为了程序打包发布,我这采用的第二种方法,具体代码如下:Private Su
8、b Form_Load()Dim str As Stringstr = App.Path 获得执行程序的绝对路径,从而得到数据库的绝对路径If Right(str, 1) “ Thenstr = str + “End Ifstr = “Provider=Microsoft.Jet.OLEDB.4.0;Persist Security Info=False;Data Source=“ & str & “databasely.mdb“Adodc1.ConnectionString = strAdodc1.CommandType = adCmdTextAdodc1.RecordSource = “s
9、elect * from borrowInfo“Adodc1.Refresh.End Sub将这些代码放入窗体的 Form_Load 过程中即可。这的 Adodc1 是我所引入的ADODC 控件的名字。如果需要数据库中的数据在 DataGrid 中显示,需要将DataGrid1 的 DataSource 属性值设置为 Adodc1。2、 插入操作将用户输入控件中的数据,现保存到 Adodc 的游标中,然后通过Adodc1.Recordset.AddNew 和 Adodc1.Recordset.Update 完成将数据保存到数据库。代码:Adodc1.Recordset.AddNew 在游标中添
10、加新纪录Call Form_LoadDateToRecordset 调用自己定义的过程 Form_LoadDateToRecordset,将用户输入的数据保存到游标中Adodc1.Recordset.Update更新游标内容,完成插入操作3、 更新操作和插入操作有点相似,不过不需要在游标中添加新纪录,更新游标中的数据然后将游标中的内容写入数据库。即可更新数据库。代码:Call Form_LoadDateToRecordsetAdodc1.Recordset.Update4、 删除操作将游标中的当前纪录删除,为了安全,删除前先进行检测判断当前游标中是否有数据。代码:If Adodc1.Recor
11、dset.BOF = False And Adodc1.Recordset.EOF = False ThenOn Error Resume NextAdodc1.Recordset.DeleteIf Adodc1.Recordset.EOF = True ThenAdodc1.Recordset.MoveLastIf Adodc1.Recordset.BOF = True ThenCall Form_ClearControlsMsgBox “没有数据了“, , “Error“End IfEnd IfEnd If5、 查询操作在 Adodc1 现在的游标中通过 Adodc1.Recordset.
12、Filter 进行匹配。代码:Dim strFilter As String定义 strFilter 为匹配条件strFilter = ComboSearchItem.Text & “=“ & txtSearchInfo.Text & “将用户选择的匹配类型和输入的匹配条件赋值给 strFilterAdodc1.Recordset.Filter = (strFilter)6、 关闭数据库连接用 Adodc1.Recordset.Close 就可以实现了。心得&体会:系统的学习并实践了从数据库设计到用 vb 完成系统。学习了很多东西,有数据库方面的也有 vb 程序设计方面的。学习到的具体内容我不
13、想一一列举,这个很多也很杂。我只想说说我的心得。1、 静则思,思者进。 (这句话不是我说的,但对我很有帮助。我当时不知道怎么用 vb 操作数据库时就是想起这句话,才静下心来找资料学习)2、 自信点,许多东西只要我们想做,总是能做好的。第四步:总结和进一步设想通过本次我们不但学习了数据库设计各个阶段同时学习了用 vb 通过软件工程的思想开发计算机应用程序。大家都有不小的收获,这里我总的总结一下。1、 本系统采用 vb + access 开发,以济南大学图书馆为模型,适用于任何图书管理部门,可以运行于任何版本的 windows 系统上。2、 系统可以完成的功能:学生借书、还书,图书入库、更新、查询、删除,系统用户的添加、用户密码的更改。3、 系统的不足 & 改进:I、系统采用很原始的人工手动输入,可以通过采用射频技术实现自动借还图书。II、用 access 作为数据库,这对一个大型的图书馆不太适合,且 access 的安全性、并发行等方面做得都不是太好,所以以后应用 ms sql 作为数据库系统。III、系统有的地方测试可能不够严格,所以存在不少 bug。这个可以通过黑盒、白盒等测试计术来完善。
Copyright © 2018-2021 Wenke99.com All rights reserved
工信部备案号:浙ICP备20026746号-2
公安局备案号:浙公网安备33038302330469号
本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。