21世纪,人类社会正面临知识经济和信息社会的急剧变革,世界各个角落的人们都强烈地感受到新时代的冲击与震撼。下面是我为大家整理的图书馆管理系统设计论文,供大家参考。
图书馆管理系统设计论文篇一图书管理系统设计
图书馆管理系统设计论文摘要
【摘要】本文介绍了利用ASP+Access编写图书管理系统的实现主要步骤与部分技术代码。
图书馆管理系统设计论文内容
【关键字】ASPAccess
随着计算机 网络技术 的普及和发展,现已逐渐进入信息化社会。人们对信息和数据的利用与处理也已进入自动化、网络化和社会化的阶段,因此,开发基于网络平台的图书管理信息系统已经成为图书管理部门的必要因此,我按照图书管理部门的需要,采用ASP+Acces实现了此图书管理系统。
一、ASP+Access
ASP是Active Server Page的缩写,意为“动态服务器页面”。ASP是微软公司开发的代替CGI脚本程序的一种应用,它可以与数据库和 其它 程序进行交互,是一种简单、方便的编程工具。
Microsoft Office Access(前名 Microsoft Access)是由微软发布的关联式数据库管理系统。它结合了Microsoft Jet Database Engine 和 图形用户界面两项特点,是 Microsoft Office的成员之一。
由于Access存储方式简单,易于维护管理、移植性好,所以本系统采用ASP做为编程工具、Access做数据库来开发
二、系统模块
此系统共分为八大模块,包括图书简介、 规章制度 、图书录入、归还图书、图书查询、新购图书、未归图书、系统维护。名模块的功能如下:
一图书简介:把图书进行分类和定义索书号,以方便查询。
二规章制度:主要介绍图书管理的订购、借阅、归还等制度。
三图书录入:对新购图书按书名、作者、分类、编号等图书信息进行录入。
四图书归还:此模块是图书管理员对归还的图书,按照图书编号进行入库管理。
五图书查询:按图书信息一些主要字段对数据库进行查询并显示。
六新购图书:查询某一时间段以后所购买的图书并显示。
七未归图书:显示未归的图书,并分页显示。
八系统维护:对数据库进行备份和恢复。
三、设计数据库
此图书管理系统数据库里主要有以下几个表:
User:用来存储图书管理员的用户名和密码。字段为user、pwd。
Menu:存储程序主页面的菜单名称和链接地址。字段为ID、父菜单ID、位置、URl、字体颜色、菜单项。
Bookinfo:用来存储图书的各种信息。字段为书名、作者、图书分类、图书编号、索书号、出版社、版期版次、购入日期、价格、排架号、是否借阅、借阅日期、应归还日期、借阅科室、借阅人、备注。
Dept:用来存储科室名称。字段为dept。
四、程序设计
一登录模块及Session的使用
由于此系统有些功能是不允许普通用户使用的,如图书录入、图书归
还等模块,所以本系统采用以管理员登录的方式,来判断是何种用户使用本系统,如果是普通用户,点击“以普通用户登录”,就可以使用本系统,但图书录入、归还图书和系统维护等模块不能使用。
由于有些功能模块不允许普通用户使用,故在登录模块程序语句定义一个Session:Session("UserAcc") = Trim(rs("User"))。 Session在计算机中,尤其是在网络应用中,称为“会话”,用于保持状态的基于 Web 服务器的 方法 。Session 允许通过将对象存储在 Web 服务器的内存中在整个用户会话过程中保持任何对象。因此,在限制普通用户使用并用If判断Session("UserAcc")是否为空即可。
二表单验证
在图书录入模块中,需要填写图书的各种信息,在提交表单时如果某
些信息为空,IE就会显示出错,因此,在提交表单之前对表单进行验证,JavaScript 可用来在数据被送往服务器前对 HTML 表单中的这些输入数据进行验证,只需编写一个函数就可以实现。函数如下
function checkinput() {
if (frm.bookname.value=='') {
alert('请输入书名')
frm.bookname.focus()
return false
}
}
在提交按钮代码中加入OnSubmit="Return checkinput()"就可以完成对表单的验证了。
三数据库连接
对于Access数据库,一个文件就是一个数据库,所以可以利用数据驱动程序直接访问数据,这种方法需要利用动态连接字符串建立一个连接,具体连接字符如下:
Dim conn, connstr,db
db="./data/tushu.mdb"
connstr="Provider=Microsoft.Jet.OLEDB.4.0DataSource="&Server.MapPath(db)
Set conn=Createobject("ADODB.Connection")
conn.Open connstr
这样就可连接数据了,再用SQL语句就可以读取表中数据了:
Set rs=CreateObject("ADODB.RecordSet")
sql="Select * From bookinfo"
rs.Open sql,conn,1,3
四对数据库的 *** 作
连接好数据库后,我们就可以对表bookinfo的记录进增加、删除、修改等 *** 作了。具体代码及释义如下:
(1):增加:
bianhao=Trim(Request("bianhao"))
sql="Select * From bookinfo Where 图书编号='"&bianhao &"'"
rs.Open sql,conn,1,3
If rs.recordcount<>0 Then
Response.Write "此图书编号已存在,请重新输入"
Response.Write "
"
Response.Write ""
Response.Write "返 回"
Else
注:在增加信息时,必须检索图书编号是否唯一,如不唯一会出给出提示:“此图书编号已存在,请重新输入”
rs.addnew
rs("书名")=trim(request("bookname"))
rs(“作者")=trim(request("author"))
……
rs.update
end if
Response.Redirect "addbook.html"
end if
set rs=nothing
(2)删除
本系统“删除”图书记录功能在查询模块中执行,但必须以管理员身份登录,才能显示对记录进行 *** 作的功能:
删除记录采用SQL中的delete语句,代码如下:
bh=Request("bianhao")
If bh<>"" Then
conn.Execute "Delete From bookinfo Where 图书编号='"&bh &"'"
End If
(3)修改
修改只需rs.update命令即可完成,这里不再赘述。
(4)查询
本系统有精确查询、模糊查询、分类查询、编号查询、索书号查询、借阅人查询共六种方法。用SQL中select…where…就可以完成查询功能。如按分类查询:
tiaojian=Trim(request("tiaojian"))
Set rs=CreateObject("ADODB.RecordSet")
sql="select * from bookinfo where 图书分类= '"&tiaojian &"' order by 图书编号 desc"
rs.Open sql,conn,1,1
五、小结
此图书管理基本上可以实现图书管理的大部份工作,实现图书的计算机管理,方便借阅人员查询和借阅图书,更好的利用图书资源,把图书管理员从手工记录管理图书中解脱出来,提高了工作效率。
图书馆管理系统设计论文文献
[1]伍云辉. 程序天下 电子工业出版,2008
[2]武延军,赵彬.精通ASP网络编程. 人民邮电出版社,2000
[3][美]Michael Moncur JavaScript 入门经典 人民邮电出版,2007
图书馆管理系统设计论文篇二图书管理信息系统设计
图书馆管理系统设计论文摘要
提要作为信息资源的集散地,图书馆在高校中的作用是尤为重要的,而图书馆传统人工管理方式已经无法快速、高效地应付日益增长的信息数据。随着计算机技术的飞速发展,使各行各业在计算机技术应用方面得到了广泛的普及和使用。因此,图书管理信息系统也以方便、快捷、费用低的优点正慢慢地进入人们的生活,将传统的图书管理方式彻底解脱出来,从而使人们有更多的时间来获取信息、了解信息、掌握信息,更好地发挥图书馆强大的资源优势。
图书馆管理系统设计论文内容
关键词:图书管理信息系统数据库应用Visual Foxpro语言windows HC
中图分类号:G251文献标识码:A
图书管理系统是典型的信息管理系统(MIS),其开发主要包括后台数据库的建立和维护以及前端应用程序的开发两个方面。对于前者要求建立起数据一致性和完整性强、数据安全性好的库而对于后者则要求应用程序功能完备,易使用等特点。本是从我校图书馆的馆藏规模和实际 *** 作流程程出发,针对图书馆管理的现状,经过详细的系统调查,结合效用和成本多方要素。利用Visual Foxpro6.0作为开发工具,为图书馆开发出的一个实用的单机版图书馆管理信息系统。全文共分为五部分,其分别为绪论、系统分析阶段、系统设计阶段、系统实施阶段、系统测试。
一、绪论
(一)系统开发背景。目前,在一些高校图书管理中,师生查找图书都是采用传统的查询方法,让读者在图书分类架上一本本地去查找,这样不仅很难找到自己所需要的图书,而且费时费力。而图书管理员在办理借书登记、查询读者借书记录时,管理人员必须在借书记录上一个个去查找,而要找到借书记录并删除该记录是件很麻烦的事情。每当新书入库时,图书管理员既要填写新书入库卡片,又要填写新书入库账目,不仅工作量大,而且在新书入库后要经历较长的时间方能借出。另外,因图书数量有限,必须对图书实行限量借阅,因此要实施d性借书方法是件很困难的事。
为提高图书查询效率,减少系部图书管理员的工作负担,有必要开发一个小型图书管理软件来对图书实施有效管理。该系统应具备以下功能:(1)能对各类图书实行分类管理(2)提供必要的读者信息(3)能进行各种高级查询(4)具有图书检索功能等。这样,不仅能较好地帮助读者在最短的时间内找到自己所需要的图书书目、编号,而且能让图书管理员以最高的效率办理借阅手续。
(二)数据库概述。从20世纪五十年代中期开始,计算机的应用由科学研究部门逐步扩展至企业、行政部门。至六十年代,数据处理成为计算机的主要应用。数据库技术作为数据管理技术,是计算机软件领域的一个重要分支,产生于六十年代末。现已形成相当规模的理论体系和实用技术。
数据库(Database)DB是统一管理的相关数据的集合。
数据库管理系统(Database Managerment System)DBMS是位于用户和 *** 作系统 之间的一层数据管理软件,为用户或应用程序提供访问DB的方法,包括DB的建立、查询、更新及各种数据控制。
数据库系统(Database System)DBS是实现有组织地、动态地存储大量关联数据,方便多用户访问的计算机软、硬件和数据资源组成的系统,即采用了数据库技术的计算机系统。
数据库技术是一门研究数据库的结构、存储、管理和使用的软件学科。
二、系统分析阶段
(一)系统可行性分析。系统可行性分析包括:技术的可行性、经济可行性、法律因素可行性。
技术可行性:结合本校图书馆规模和平时业务量的具体情况,本系统采用Visual Foxpro6.0作为开发平台,可以很容易实现图书馆相关信息的记录、维护、检索,并且可以在不添加任何设备的情况下,以较少的人力较快地完成系统的设计,实现系统的功能。
经济可行性:不需要额外开支,用现有的人力物力就可实现,软件成本很低。
法律可行性研究:研究在系统开发过程中可能涉及的各种合同、侵权、责任以及各种与法律相抵触的问题。
(二)系统需求分析
1、图书管理信息系统的总体功能要求。简单的图书管理系统主要包括下面的功能:①借书处理:完成读者借书这一业务流程,核心为快速检索到学生需要的书籍。②还书处理:完成读者还书这一业务流程。③新书上架:完成新书资料的录入工作。④旧书下架:完成图书资料的删除工作。⑤读者查询:根据读者号,查询读者借阅情况,能够对读者的基本信息资料进行管理。⑥相关帮助:便于新的系统使用者能够快速掌握该系统的使用 *** 作。
2、图书管理信息系统的性能需求。①要求有较强的 系统安全 性,对一定范围和程度内用户的错误 *** 作有相应的系统自我保护功能。②系统的维护时间不能超过系统总运行时间的千分之五,系统每次的维护时间不能超过系统总运行时间的千分之一,系统的故障恢复时间不得超过系统故障时间的百分之五。③其他性能要求以其相关或类似的系统为参考。
三、系统设计阶段
(一)系统功能模块设计。鉴于以上各项功能要求,将该系统划分为以下六个模块:
1、图书信息模块。对图书的基本信息进行录入、删除、修改以前信息和进行简单查询功能。
2、查询检索模块。可对书目的基本信息进行检索,其查询条件可以是按分类检索也可以是按照作者名、图书名称或出版社进行检索。同时,也可对读者的基本信息进行检索,查阅其借阅信息。
3、读者管理模块。对读者的基本信息进行录入管理,可自动生成会员代号,可自动记录会员的借阅信息。
4、数据维护模块。可对数据库中的各项基本数据信息进行数据备份和数据恢复,并可实现数据备份文件存贮路径的自由选择。
5、报表输出模块。对图书的基本信息、会员的基本信息、会员的借阅信息等数据可按照查询条件的不同按要求打印输出。
6、帮助模块。可以提供关于图书管理信息系统各项 *** 作的详细帮助信息,并可实现对不同 *** 作的定点帮助提示。
(二)数据库设计
1、数据描述
(1)静态数据描述。①图书一级分类表:包括一个数据表。其中的主要信息有:分类编号和一级分类名称。一级分类中将图书共分五大类,具体分类方法、编号和分类名称参照国家统一分类方法的规定。②图书二级分类表:包括五个数据表。其中的主要信息有:二级分类的编号和分类名称。二级分类中将图书共分为二十二个小类,并分别隶属于一级分类的五个大类中,其具体分类方法、编号和分类名称参照国家统一分类方法的有关规定。③图书明细分类表:包括二十二个数据表。其中的主要信息有:明细分类的编号和分类名称。明细分类又将二十二个小类明细的分为若干细小类别,其具体的分类方法、编号和分类名称参照国家统一分类方法的有关规定。
以上数据均按国家统一规定设置录入,不能做太大改变,分类名称可以有一定的缩略但不能影响其原有的意义。系统设计完成后不可以通过录入、删除的方式进行修改。
(2)动态数据
①图书的基本数据。包括一个数据表。其中的主要数据有图书编号:是对录入图书的统一编号,以便唯一区别图书图书名称:图书出版时的封面印刷名称作者:图书的编写者或编写单位或组织出版社:出版发行该册图书的发行单位录入日期:该册图书入库的时间借阅次数:该图书总的被借阅次数类别编号:给图书所属的明细分类的类别号,它应与明细分类表中的图书的类别编号一致简介:对该册图书的内容总体概括介绍。
②读者基本数据:包括一个数据表。其中的主要数据有:读者代号:读者的统一编号,由系统自动生成,唯一的标示一个会员的身份姓名:读者的真实姓名电话:读者的有效联系电话,可选择填写地址:读者的有效联系地址,可选择填写身份z号:读者的身份z号码,可选择填写注册日期:读者本人正式注册成功时的日期(为系统自动填写)。备注:读者的个人其他资料。
以上两部分数据的录入具有一定的界面,并提供修改的方式。还提供随时的查询,对查询结果有相应的显示和打印输出,对全体的数据可进行备份与恢复。
③借阅记录。包括一个数据表。其中的主要数据有:读者代号、图书编号、借阅日期。这些数据信息都是由系统自动填写。此表中的所有数据不提供修改方式,只供查阅、显示和打印输出。可以对全体数据进行备份和恢复。
④登录密码。包括一个数据表。其主要数据有:管理员代号、密码、权限。
2、数据库描述。该系统建立一个数据库,其中包括三十二个数据表。全部用Visual Foxpro实现。其中,部分数据表的结构和联系如图1所示。(图1)其他分类数据表的连接通过“下级分类表名”实现连接调用。
3、数据采集。对于图书分类数据表的信息参照国家图书分类方法对于图书基本信息数据可通过对现存图书进行分类录入对于读者方面的信息数据可以在系统运行使用中获得。
(三)用户界面设计。本系统设计原则:1、界面美观、 *** 作方便并能高效率地完成工作2、界面根据用户需求设计3、界面能引导用户 *** 作的功能,并能提供一些帮助功能。
主要的用户界面有:1、登录界面2、主表单界面3、各类信息查询4、读者信息管理列表5、图书信息管理列表等。
四、系统实施阶段
(一)计算机系统的性能和软硬件环境。在软件方面本系统运行平台为Windows2000专业版,开发工具采用易学易用的软件开发工具Visual Foxpro6.0。因Visual Foxpro6.0在应用程序的开发上具有灵活、效率高等特点和使用简便的数据库管理功能。硬件要求:Inter PentiumⅢ、128M内存、40G硬盘等。
(二)编写程序。依据各阶段的开发文档,使用Visual Foxpro6.0进行程序编写。此系统的编码设计(表单设计、代码设计、变量定义、控件的定义)严格按照大众化的标准和风格。
对于系统的帮助功能的实现,则使用windows help compiler来单独编译,最后通过Visual Foxpro提供的接口命令(set help to)和系统相连。帮助文件的数据字典、源代码见附件。
五、系统测试
测试的步骤主要有以下三个方面:1、单元测试:采用的是白盒测试法,检查模块控制结构的某些特殊路径2、综合测试:采用的是自顶向下集成法3、确认测试包括:功能测试、性能测试。
有关图书馆管理系统设计论文推荐:
1. 图书管理系统毕业论文
2. 浅谈图书馆管理论文
3. 关于图书馆设计论文
4. 图书馆管理毕业论文范文
5. 有关图书馆结构设计论文
6. 图书馆管理论文
一 程序设计说明书【设计题目】 图书馆借阅管理
【问题描述】图书馆,适合用C++面向对象的功能来描述。图书馆管理系统分为借书、还书、图书管理和读者服务等四个部分。设计一个读者类Reader,记录每个读者基本信息;读者库类Rdatabase,记录所有读者信息;图书类Book, 记录每本书的基本信息;图书库类Bdatabase, 记录所有图书信息。
【基本要求】
1读者库类RDatabase中,其构造函数中,将read.txt文件中所有读入读者记录rede[]中。处理完毕,在析构函数中将read[]中的所有未删记录写入到read.txt中。
2图书库类BDatabase中,其构造函数中,将book.txt文件中所有读入图书记录book[]中。处理完毕,在析构函数中将book[]中的所有未删记录写入到book.txt中。
3 利用构造函数完成读者和图书数据初始化,完成内存分配。程序结束前,析构函数完成所申请的堆内存空间。
4 编写主函数,对所编写的矩阵类进行全面测试。要求用户界面采用菜单方式。测试中需要读者和图书数据通过I/O流从磁盘文件读入,同时显示在屏幕上。得到的数据通过I/O流写入磁盘文件保存,同时显示在屏幕上。
5 源程序中要有充分的注释,报告中要有详细的流程图和文字材料。
【类的设计】
该程序包含了四个类,如下:
1.Reader类,有读者的基本管理功能,具有以下私有数据:
int tag//删除标记 1:已删;0:未删
int no//读者编号
char name[10]//读者姓名
int borbook[Maxbor]//所借图书
2.读者库类Rdatabase, 具有以下私有数据:
int top//读者记录指针
Reader read[Maxr]//读者记录
3.图书库类Book,有一本图书的基本功能,有以下私有数据:
int tag//删除标记 1:已删;0:未删
int no//图书编号
char name[20]//书名
int onshelf//是否在架 1在架 0已借
4.图书库类BDatabase,有以下私有数据:
int top//图书记录指针
Book book[Maxb]//图书记录
【特殊函数的设计说明】
构造函数
1.Reader类中构造函数Reader(),初始化函数;
2.读者库类RDatabase中,其构造函数Rdatabase(),将read.txt文件中所有读入读者记录rede[]中。
3.Book类中构造函数Book(),初始化函数;
4.图书库类BDatabase中,其构造函数中,将book.txt文件中所有读入图书记录book[]中。
拷贝构造函数
Reader类中的拷贝构造函数将getname()的返回值读者姓名拷贝到setname()中,Book类中的拷贝构造函数将getname()函数的返回值图书名拷贝到图书名设置函数setname()中。
析构函数
1.读者库类RDatabase中,其析构函数~Rdatabase(),将read[]中的所有未删记录写入到read.txt中;
2.图书库类BDatabase中,其析构函数~Bdatabase(),将book[]中的所有未删记录写入到book.txt中。
运算符重载
重载了“=”,当比较读者编号和图书编号时,重载;重载位运算符“〈〈”和“〉〉”等。
【主要函数算法流程图】
【程序的使用方法】
1.进入 *** 作页面,按提示 *** 作;
2.首先,新增图书和读者信息,之后就可以对以存在的信息进行 *** 作;
3. *** 作当中,可以随时增加,更改和删除图书或读者信息;
4.当选择退出时,进行清屏。
二 程序上机调试报告
【语法错误及其排除】
1.在敲程序时,有很多拼写错误,例好多处把Readdata()误打Readdate();结束的分号,在不同的输入法状态下输入,这些小错误刚开始很难发现,不过有了经验,就很容易了。
2.创建新的构造函数时,使用出现了错误。重载构造函数要注意函数的访问权限,结果就不会出现错误。
【算法错误及其排除】
1.读者类中借书 *** 作函数中,采用循环语句时判断读者已借图书量时for(int i=0i<Maxbori++)误写为for(int i=1i<Maxbori++),使循环发生错误。
2.指针使用错误,指针b和r混淆,导致编译错误得到“error C2660: 'retbook' : function does not take 1 parameters”错误报告。
#include <iostream>#include <iomanip>
#include <string>
#include <fstream>//输入/输出文件流类
using namespace std
const int Maxr=100//最多的读者
const int Maxb=100//最多的图书
const int Maxbor=5//每位读者最多借五本书
//读者类,实现对读者的信息的描述
class Reader
{
private:
int tag//删除标记 1:已删 0:未删
int no//读者编号
char name[10]//读者姓名
int borbook[Maxbor]//所借图书
public:
Reader() {}
char *getname() //获取姓名
int gettag() //获取删除标记
int getno() //获取读者编号
void setname(char na[]) //设置姓名
{
strcpy(name,na)
}
void delbook()//设置删除标记 1:已删 0:未删
void addreader(int n,char *na)//增加读者
{
tag=0
no=n
strcpy(name,na)
for(int i=0i<Maxbori++)
borbook[i]=0
}
void borrowbook(int bookid)//借书 *** 作
{
for(int i=0i<Maxbori++)
{
if (borbook[i]==0)
{
borbook[i]=bookid
return
}
}
}
int retbook(int bookid)//还书 *** 作
{
for(int i=0i<Maxbori++)
{
if(borbook[i]==bookid)
{
borbook[i]=0
return 1
}
}
return 0
}
void disp()//读出读者信息
{
cout <<setw(5) <<no <<setw(10) <<name<<"借书编号:["
for(int i=0i<Maxbori++)
if(borbook[i]!=0)
cout <<borbook[i] <<"|"
cout <<"]"<<endl
}
}
//读者类库,实现建立读者的个人资料
class RDatabase
{
private:
int top//读者记录指针
Reader read[Maxr]//读者记录
public:
RDatabase() //构造函数,将reader.txt读到read[]中
{
Reader s
top=-1
fstream file("reader.txt",ios::in)//打开一个输入文件
while (1)
{
file.read((char *)&s,sizeof(s))
if (!file)break
top++
read[top]=s
}
file.close()//关闭 reader.txt
}
void clear()//删除所有读者信息
{
top=-1
}
int addreader(int n,char *na)//添加读者时先查找是否存在
{
Reader *p=query(n)
if (p==NULL)
{
top++
read[top].addreader(n,na)
return 1
}
return 0
}
Reader *query(int readerid)//按编号查找
{
for (int i=0i<=topi++)
if (read[i].getno()==readerid &&
read[i].gettag()==0)
{
return &read[i]
}
return NULL
}
void disp() //输出所有读者信息
{
for (int i=0i<=topi++)
read[i].disp()
}
void readerdata()//读者库维护
~RDatabase() //析构函数,将read[]写到reader.txt文件中
{
fstream file("reader.txt",ios::out)
for (int i=0i<=topi++)
if (read[i].gettag()==0)
file.write((char *)&read[i],sizeof(read[i]))
file.close()
}
}
void RDatabase::readerdata()
{
char choice
char rname[20]
int readerid
Reader *r
while (choice!='0')
{
cout <<"\n\n\t\t\t读 者 维 护\n\n\n\t\t 1 新 增\n\n\t\t 2 更 改\n\n\t\t 3 删 除\n\n\t\t 4 查 找\n\n\t\t 5 显 示\n\n\t\t 6 全 删\n\n\t\t 0 退 出"<<endl
cin >>choice
switch (choice)
{
case '1':
cout <<"输入读者编号:"
cin >>readerid
cout <<"输入读者姓名:"
cin >>rname
addreader (readerid,rname)
break
case '2':
cout <<"输入读者编号:"
cin >>readerid
r=query(readerid)
if (r==NULL)
{
cout <<" 该读者不存在 "<<endl
break
}
cout <<"输入新的姓名:"
cin >>rname
r->setname(rname)
break
case '3':
cout <<" 输入读者编号:"
cin >>readerid
r=query(readerid)
if (r==NULL)
{
cout <<" 该读者不存在" <<endl
break
}
r->delbook()
break
case '4':
cout <<"读入读者编号:"
cin >>readerid
r=query(readerid)
if (r==NULL)
{
cout <<"该读者不存在"<<endl
break
}
r->disp()
break
case '5':
disp()
break
case '6':
clear()
break
default:cout<<"输入错误,请从新输入:"break
}
}
}
//图书类,实现对图书的描述,图书的编号,书名,借出,还入等
class Book
{
private:
int tag//删除标记 1:已删 0:未删
int no//图书编号
char name[20]//书名
int onshelf//是否再架 1:再架 2:已借
public:
Book(){}
char *getname() //获取姓名
int getno()//获取图书编号
int gettag()//获取删除标记
void setname(char na[])//设置书名
{
strcpy(name,na)
}
void delbook()//删除图书
void addbook(int n,char *na)//增加图书
{
tag=0
no=n
strcpy(name,na)
onshelf=1
}
int borrowbook()//借书 *** 作
{
if (onshelf==1)
{
onshelf=0
return 1
}
return 0
}
void retbook()//还书 *** 作
{
onshelf=1
}
void disp()//输出图书
{
cout <<setw(6) <<no <<setw(18) <<name <<setw(10)
<<(onshelf==1? "在架":"已借") <<endl
}
}
//图书库类,实现对图书的维护,查找,删除等
class BDatabase
{
private:
int top//图书记录指针
Book book[Maxb]//图书记录
public:
BDatabase()//构造函数,将book.txt读到book[]中
{
Book b
top=-1
fstream file("book.txt",ios::in)
while (1)
{
file.read((char *)&b,sizeof(b))
if (!file) break
top++
book[top]=b
}
file.close()
}
void clear()//全删
{
top=-1
}
int addbook(int n,char *na)//增加图书
{
Book *p=query(n)
if (NULL==p)
{
top++
book[top].addbook(n,na)
return 1
}
return 0
}
Book *query(int bookid)//查找图书
{
for (int i=0i<=topi++)
if (book[i].getno()==bookid &&book[i].gettag()==0)
{
return &book[i]
}
return NULL
}
void bookdata()//图书库维护
void disp()
{
for (int i=0i<=topi++)
if (book[i].gettag()==0)
book[i].disp()
}
~BDatabase()//析构函数,将book[]写到book.txt文件中
{
fstream file("book.txt",ios::out)
for (int i=0i<=topi++)
if (book[i].gettag()==0)
file.write((char *)&book[i],sizeof(book[i]))
file.close()
}
}
void BDatabase::bookdata()
{
char choice
char bname[40]
int bookid
Book *b
while (choice!='0')
{
cout <<"\n\n\n\t\t\t图 书 维 护 "<<endl<<endl
cout<<"\t\t1 新 增\n \t\t2 更 改\n\t\t3 删 除\n\t\t4 查 找\n\t\t5 显 示\n\t\t6 全 删\n\t\t0 退 出"<<endl
cin >>choice
switch (choice)
{
case '1':
cout <<"输入图书编号:"<<endl
cin >>bookid
cout <<"输入图书书名:"<<endl
cin >>bname
addbook(bookid,bname)
break
case '2':
cout <<"输入图书编号:"<<endl
cin >>bookid
b=query(bookid)
if (b==NULL)
{
cout <<" 该图书不存在 "<<endl
break
}
cout <<"输入新的书名:"<<endl
cin >>bname
b->setname(bname)
break
case '3':
cout <<" 读入图书编号:"<<endl
cin >>bookid
b=query(bookid)
if (b==NULL)
{
cout <<" 该图书不存在" <<endl
break
}
b->delbook()
break
case '4':
cout <<" 读入图书编号:"<<endl
cin >>bookid
b=query(bookid)
if (b==NULL)
{
cout <<" 该图书不存在"<<endl
break
}
b->disp()
break
case '5':
disp()
break
case '6':
clear()
break
default:cout<<"输入错误,请从新输入:"
}
}
}
//main() 函数的实现,程序的主界面的引导
void main()
{
char choice
int bookid,readerid
RDatabase ReaderDB
Reader *r
BDatabase BookDB
Book *b
while(choice!='0')
{
cout <<endl<<endl<<"\t\t\t 图 书 管 理 系 统\n\n\n"
cout <<"\t\t\t1 借 书\n\n\t\t\t2 还 书 \n\n\t\t\t3 图 书 维 护\n\n\t\t\t4 读 者 维 护\n\n\t\t\t0 离 开"<<endl
cin >>choice
switch (choice)
{
case '1':
cout <<" 借书 读者编号:"
cin >>readerid
cout <<" 图书编号: "
cin >>bookid
r=ReaderDB.query(readerid)//按编号查找
if (NULL==r)
{
cout <<" 不存在该读者,不能借书"<<endl
break
}
b=BookDB.query(bookid)
if (b==NULL)
{
cout <<" 不存在该图书,不能借书"<<endl
break
}
if (b->borrowbook()==0)
{
cout <<" 该图书已借出,不能借书"<<endl
break
}
r->borrowbook(b->getno())
break
case '2':
cout<<"还书\n 读者编号:"
cin >>readerid
cout <<" 图书编号:"
cin >>bookid
r=ReaderDB.query(readerid)
if (r==NULL)
{
cout <<" 不存在该读者,不能还书" <<endl
break
}
b=BookDB.query(bookid)
if (b==NULL)
{
cout <<" 不存在该图书,不能还书" <<endl
break
}
b->retbook()
r->retbook(b->getno())
break
case '3':
BookDB.bookdata()
break
case '4':
ReaderDB.readerdata()
break
default:cout<<"输入错误,请从新输入:"
}
}
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)