.net图书管理系统设计报告

时间:2024.4.20

题 目 图书管理系统

图书管理系统

一、实验目的、内容

图书管理系统,此实验的主要内容及目的是熟悉VC++.net的C/S结构,掌握如何通过MFC ODBC访问数据库。

对于图书的借书和还书过程,相信我们每个学生对此过成已经很熟悉。在计算及尚未在图书馆广泛使用之前,借书和还书主要是依靠手工过程。一个最典型的手工处理过程就是,读者将要借的书和借阅证交给工作人员,工作人员将每本书附带的描述书信息的信息卡和读者借阅证一起放在一个小格栏,并在借阅证和每本书上帖的节约条上填写借阅信息。这样借书过程就完成了。幻术师,读者将要还的图书交给工作人员,工作人员根据图书信息找到相应书卡和借阅证,并填写相应的还书信息。

以上所描述的手工过程的不足是显而易见的,首先处理借书还书业务流程效率很低,其次处理能力比较低。一段时间内,所能服务的读者人数是有限的。

利用计算机来处理这些流程无疑会极大程度的提高效率和处理能力。我们将会看到排队等候借书还书的队伍不那么长了,工作人员出错的概率也小了,读者可以花更多的时间在选择书可看书上。

二、实验程序设计及结构

1、需求分析(功能、类、成员)

当决定开发一个信息系统时,首先要对信息系统的需求进行分析。需求分析要做的工作是深入描述软件的功能和性能,确定软件设计的限制和软件同其他元素的接口细节,定义软件的其他有效性需求。其主要包括一下四个步骤(如下图:):

net图书管理系统设计报告

1)、获得当前系统的处理过程,在此首先假设当前系统是手工处理系统。

手工处理流程大致是这样的。读者将要借的书和借阅证交给工作人员,工作人员将每本书上贴的借阅条上填写借阅信息。这样借书过程就完成了。还书时,读者将要还的书交给工作人员,工作人员根据图书信息找到相应的书卡和借阅证,并填写相应的还书信息。

2)、抽象出当前系统的逻辑模型;

在理解当前系统“怎么做的”的基础上,抽象取出“做什么”的本质,从而当前系统的物理模型抽象出当前系统的逻辑模型。在物理模型中有许多物理因素,随着分析工作的深入,有些非本质的物理因素就成为不必要的负担,因而需要对物理模型进行分析,区分出本质的和非本质的因素,去掉那些非本质的因素即可反映系统本质的逻辑模型。

3)、建立目标系统的逻辑模型;

建立目标系统的逻辑模型,分析目标系统与当前系统逻辑上的差别,明确目标系统到底要“做什么”,从而从当前系统的逻辑模型导出目标系统的逻辑模型。在对上述流程进行分析后,我们对新的图书处理流程进行整理,图书馆开架借书还书过程如下:

借书过程:

读者从架上选到所需图书后,将图书和借书卡叫管理人员,管理人员用条码阅读器将图书和借书卡上的读者条码信息读入处理系统。系统根据读者条码从读者文件和借阅文件中找到相应记录,读者如果有下列情况之一将不予办理借书手续;

1读者所节约图书已超过该读者容许的最多借书数目; ○

2该读者记录中有止借标志; ○

3该读者还有超过归还日期而仍未归还的图书; ○

4该图书暂停外借。 ○

若读者符合所有借书条件时,予以借出。系统在借阅文件中增加一条记录记入读者条码,图书条码、借阅日期等内容。

还书过程:还书时读者只要将书交给管理人员,管理员将书中的图书条码读入系统,系统从借阅文件上找到相应的记录。同时系统对借还书日期进行计算并判断是否超期。若不超期则结束过程,若超期则计算出超期天数,罚款数,并打印罚款通知书,记入罚款文件。同时在读者记录上做止借标记。当读者交来罚款收据后系统根据读者条码查罚款文件,将相应记录写入罚款历史文件,并从罚款文件只删除该记录,同时去掉读者文件中的止借标记。

借书过程数据流图如下所示:

net图书管理系统设计报告

net图书管理系统设计报告

net图书管理系统设计报告

还书过程数据流图如下:

net图书管理系统设计报告

net图书管理系统设计报告

4)、为了对图书管理系统做完善的描述,还需要对上面得到的逻辑模型做一些补充。首先采用图形的方式描述图书管理系统的用户界面,这样做的目的是保证整个系统的用户界面的一致性,同时也有助于后续开发人员更好的理解系统需要实现的功能。

2、设计结构(包括总体结构和数据结构)

通过对图书馆的需求分析可以独处该系统涉及三个实体:读者、图书、工作人员。

这些实体涉及的数据项有:

读者:读者条码,姓名,身份证号,最多借书数,止借标志

图书:图书条码,书名,作者,出版社,出版日期,数量,停借标志 工作人员:ID,姓名,身份证号,密码职务

实体之间涉及的数据项有:

借阅文件:读者条码,图书条码,借出日期,归还日期,操作人员ID

罚款文件:读者条码,罚款天数,罚款数,罚款日期,截止日期,操作人员ID

图书管理系统需要实现的功能主要有四大模块:基本资料维护,日常维护,系统安全模块和读者查询模块。其中日常维护和基本资料维护是整个系统的核心。日常维护包括借书处理,还书处理和缴纳罚金。基本资料维护包括对读者,员工和图书等信息的维护,主要有读者信息的增删改,对员工资料进行增删改,

对员工资料进行增删改和对图书资料进行增删改。系统安全模块只是实现了最简单的系统登陆检查。读者查询也只实现了简单的查询功能。下面对具体的模块进行具体的介绍。、

借书处理的主要功能是扫描读者条形码,在数据库中插入一条借书记录,该记录包括读者条形码,提升机条形码,借出日期。

还书处理的主要功能是扫描图书条形码,在借阅文件中找到相应的记录将该记录的相应数据插入到还书记录中,同时将结束记录删除。

缴纳罚金的主要功能是输入读者条形码,显示该读者的姓名,罚款金额和过期天数,如果读者缴纳了罚金,则将读者文件的允许标志设置为“Y”删除罚款文件中该读者对应的记录,将这一条记录同时插入到罚款历史文件中。

读者查询:允许读者根据自己的条形码或姓名查询自己的

借书记录;

图书资料维护的功能包括输入新书资料,删除救赎资料,修改图书资料等。 读者资料维护的功能包括读者信息的输入,修改和删除。

工作人员信息维护主要包括工作人员信息的输入,修改和删除;

注销读者:将读者记录置止记标志,同时提供删除读者信息的功能;

系统登陆:是对用户名和输入的密码进行检查,已确定登陆用户是否合法,用户名和密码的维护是在工作人员资料维护模块中实现的。

三、设计过程

1、 建立数据库

此图书管理系统使用的后台数据库服务器为Access。做此系统所使用的所有的代码均在一下操作环境下运行通过:

操作系统:Windows XP

数据库服务器:Microsoft office Access 2007

开发工具:Microsoft Visual Studio 2008

该图书管理系统所需的库结构为:

读者文件(reader):

读者条码(reader_id)、姓名(name)、身份证号(IDCARD)、最多借书数(maxnum_can_borrow)、止借标志(flag_borrow)

图书文件(book):

图书条码(book_id)、书名(book_name)、作者(author)、出版社(press)、出版日期(press_date)、停借标志(flag_borrow)

职工文件(clerk):

职员ID(Clerk_ID)、姓名(name)、身份证号(ID_Card)、口令(Password)、职务(office)

借阅文件(borrow):

读者条码(reder_ID)、图书条码(book_id)、借出日期(borrow_date)、操作人员(B_Clerk_ID) 、ID

借阅历史文件(history):

读者条码(reader_id)、图书条码(book_id)、借出日期(borrow_date)、归还日期(return_date)、借书操作人员(B_Clerk_ID)、还书操作人员(R_Clerk_ID) 、ID

罚款文件(fine):

读者条码(reader_id)、罚款天数(days)、罚款数(amount)、罚款日期(dine_date)、操作人员(Clerk_ID)、ID

罚款历史文件(fine_history):

读者条码(reader_id),罚款天数(days),罚款数(amount),罚款日期(fine_date),解止日期(ok_date),ID

一般在设计数据库结构时,我们常常在每个表上尤其是一些存放业务流程数据的表上增加一个对用户来说没有意义的字段。这个字段一般是长整形,并设其为自动加1的identity类型,这个字段主要是为了在业务流程数据表中唯一标识一条记录。

建立数据库有很多种方式,一种是直接使用Access图形界面建立相应的数据库,这种方式的好处是操作简单,但不适用于大型系统的开发。第二种是使用辅助数据库设计的工具直接建立数据库,修改数据库。第三种是写SQL语句,将整个系统涉及的数据表,视图、触发器等用SQL语句写在一个.sql的文本文件中,再用数据库支持的批量处理SQL语句的命令执行这个文件,这种方式比较普遍。在此系统中用的是第一种方式。

3、建立工程

首先建立新工程,在此使用的是MFC App Wozard生成library.dsw工作区间,具体步骤像建立一般MFC程序一样,在此不再赘述。

建立好工程之后,开始编辑菜单。在Resource视图下的Menu文件夹中双击菜单资源菜单资源IDR_MAINFRAME,打开菜单编辑器,建立一个新的菜单,命名为“系统”,子菜单有两项,分别为“登录”和“退出”。按上述步骤建立其他菜单项,最后得到如如下图所示的菜单。

登录模块的实现:

在Resource View的Dialog文件中有机Dialog文件夹,选择Insert Dialog选项,然后右击产生的新的对话框,选择Properties,设置对话框的各个属性值。登录模块是要根据用户输入的用户名和密码与数据库Clerk中的Username和Password的比较来判断用户名和密码是否合法。用户登陆对话框如下图所示:

net图书管理系统设计报告

在资源视图中右击对话框的“登录”按钮,选择classwozard选项。双击Messages列表框的BN_CLICKED,然后确定弹出的对话框。如果要编辑代码,则单击EDIT CODE按钮,参照程序:

void CLoginDlg::OnConfirm()

{

if (!mrsDataSet.Open(AFX_DB_USE_DEFAULT_TYPE, mSqlStr)) { } if (!mrsDataSet.IsEOF()) { } else { AfxMessageBox("登录失败!"

net图书管理系统设计报告

); // Open all function for user m_bSuccess = TRUE; m_strUSERID = mrsDataSet.m_CLERK_ID ; CDialog::OnOK(); AfxMessageBox("CLERK表打开失败!"); return; mSqlStr = "SELECT * FROM CLERK WHERE NAME='"; mSqlStr = mSqlStr + m_strName; mSqlStr = mSqlStr + "' AND PASSWORD='"; mSqlStr = mSqlStr + m_strPassword; mSqlStr = mSqlStr + "'"; if (m_strName.IsEmpty()) /*判断用户名信息是否为空*/ { } AfxMessageBox("请输入用户名!"); return; UpdateData(TRUE); // TODO: Add your control notification handler code here CClerkDataSet mrsDataSet; /*声明记录集*/ CString mSqlStr;

} } m_strUSERID = _T(""); return;

按照以上步骤,在菜单的“登录”选项中单击事件编写程序如下:

void CMainFrame::OnLoginIn()

{

// TODO: Add your command handler code here CLoginDlg mDlg; if (mDlg.DoModal() == IDOK) { } else { } CString Name; Name = "当前用户:" + m_strUserName; m_wndStatusBar.SetPaneText(0,Name);

} m_bLogin = FALSE; m_strUserName = _T(""); m_strUserID = _T(""); m_bLogin = TRUE; m_strUserName = mDlg.m_strName ; m_strUserID = mDlg.m_strUSERID;

至此登录模块完成,通过对登录模块的实现,便了解了通过MFC ODBC操作数据库的基本方式。

读者资料维护模块的实现:

第一步,生成对话框IDD_READER_MAITAIN,同时生成CreaderMDlg类以及相应的空间如下所示:

对应于编辑框的成员变量设为如下名称:

enum { IDD = IDD_READER_MAINTAIN };

CString CString CString CString CString m_strReaderIDQ; m_strReaderID; m_strReaderName; m_strReaderNameQ; m_strIDCard;

第二步,在“第一笔”按钮的事件脚本中插入如下代码:

void CReaderMDlg::OnFirst()

{

// TODO: Add your control notification handler code here if(!m_rsDataSet.IsBOF())

{

}

} m_rsDataSet.MoveFirst(); DisplayRecord(); SetButtonState();

这个函数的目的是将记录集移动到第一条记录,在CReaderMDlg类中加入成员函数DisplayRecord(),程序如下:

BOOL CReaderMDlg::DisplayRecord()

{

if (m_rsDataSet.IsEOF() && m_rsDataSet.IsBOF()) { } else {

net图书管理系统设计报告

if (m_rsDataSet.IsBOF()) { } else m_rsDataSet.MoveNext(); m_strReaderID = ""; m_strReaderName = ""; m_strIDCard = "";

} } { } m_strReaderID = m_rsDataSet.m_READER_ID; m_strReaderName = m_rsDataSet.m_NAME; m_strIDCard = m_rsDataSet.m_IDCARD; if (m_rsDataSet.IsEOF()) { } m_rsDataSet.MovePrev(); UpdateData(FALSE); return TRUE;

第三步,在CReaderMDlg类中加入成员函数SetButtonState()。代码如下所示: BOOL CReaderMDlg::SetButtonState()

{

if(!m_rsDataSet.IsOpen()) { pWnd = GetDlgItem(IDC_FIRST); pWnd->EnableWindow(FALSE); pWnd = GetDlgItem(IDC_NEXT); pWnd->EnableWindow(FALSE); pWnd = GetDlgItem(IDC_PRIOR); pWnd->EnableWindow(FALSE); pWnd = GetDlgItem(IDC_LAST); pWnd->EnableWindow(FALSE); pWnd = GetDlgItem(IDC_NEW); pWnd->EnableWindow(FALSE); pWnd = GetDlgItem(IDC_EDIT); pWnd->EnableWindow(FALSE); pWnd = GetDlgItem(IDC_ENQUERY); pWnd->EnableWindow(FALSE); pWnd = GetDlgItem(IDC_DELETE); pWnd->EnableWindow(FALSE); pWnd = GetDlgItem(IDC_SAVE); pWnd->EnableWindow(FALSE); pWnd = GetDlgItem(IDC_CANCEL_REC); pWnd->EnableWindow(FALSE); return TRUE; CWnd *pWnd;

} }

上述代码中使用了函数GetDlgItem(),它是实现在制定的对话框或窗口中搜索指定的控件或子窗口。

第四步,在“Prior”按钮插入如下事件脚本:

void CReaderMDlg::OnPrior()

{

} // TODO: Add your control notification handler code here if(!m_rsDataSet.IsBOF()) { } m_rsDataSet.MovePrev(); DisplayRecord(); SetButtonState();

第五步,在“Next”按钮如下事件脚本:

void CReaderMDlg::OnNext()

{

} // TODO: Add your control notification handler code here if(!m_rsDataSet.IsEOF()) { } m_rsDataSet.MoveNext(); DisplayRecord(); SetButtonState();

第六步,在“Last”按钮插入如下事件脚本:

void CReaderMDlg::OnLast()

{

} // TODO: Add your control notification handler code here if(!m_rsDataSet.IsEOF()) { } m_rsDataSet.MoveLast(); DisplayRecord(); SetButtonState();

第七步,在“New”按钮插入如下事件脚本:

void CReaderMDlg::OnNew()

{

} // TODO: Add your control notification handler code here m_strReaderID = ""; m_strReaderName = ""; m_strIDCard = ""; UpdateData(FALSE); m_bEdit = TRUE; m_bAdd = TRUE; SetButtonState(); SetTextState(); CWnd *pWnd; pWnd = GetDlgItem(IDC_READER_ID); pWnd->SetFocus();

第八步,在CreaderMDlg类中加入成员函数SetTextState(): BOOL CReaderMDlg::SetTextState()

{

} pWnd = GetDlgItem(IDC_READER_NAME_FOR_Q); pWnd->EnableWindow(TRUE); pWnd = GetDlgItem(IDC_READER_ID_FOR_Q); } else { pWnd = GetDlgItem(IDC_READER_NAME); pWnd->EnableWindow(FALSE); pWnd = GetDlgItem(IDC_READER_ID); pWnd->EnableWindow(FALSE); pWnd = GetDlgItem(IDC_IDCARD); pWnd->EnableWindow(FALSE); if (m_bEdit) { pWnd = GetDlgItem(IDC_READER_NAME); pWnd->EnableWindow(TRUE); pWnd = GetDlgItem(IDC_READER_ID); if (m_bAdd) pWnd->EnableWindow(TRUE); pWnd->EnableWindow(FALSE); else pWnd = GetDlgItem(IDC_IDCARD); pWnd->EnableWindow(TRUE); CWnd *pWnd;

} pWnd->EnableWindow(TRUE); return TRUE;

第九步,在“Edit”按钮插入如下事件脚本: void CReaderMDlg::OnEdit()

{

} // TODO: Add your control notification handler code here m_bEdit = TRUE; SetButtonState(); SetTextState(); CWnd *pWnd; pWnd = GetDlgItem(IDC_READER_NAME); pWnd->SetFocus();

第十步,在“Save”按钮插入如下事件脚本: void CReaderMDlg::OnSave()

{

// m_rsDataSet.m_FLAG_BORROW = "Y";

m_rsDataSet.Update(); m_rsDataSet.Requery(); m_bAdd = FALSE; m_bEdit = FALSE; DisplayRecord(); // TODO: Add your control notification handler code here UpdateData(TRUE); if (m_strIDCard.IsEmpty() || m_strReaderName.IsEmpty() || { } if (m_bAdd) { } else { } m_rsDataSet.m_IDCARD = m_strIDCard; m_rsDataSet.m_NAME = m_strReaderName; m_rsDataSet.m_READER_ID = m_strReaderID; m_rsDataSet.Edit(); m_rsDataSet.AddNew(); AfxMessageBox("请输入相应数据!"); return; m_strReaderID.IsEmpty())

} SetButtonState(); SetTextState();

第十一步,在“Cancel”按钮插入如下事件脚本: void CReaderMDlg::OnCancelRec()

{

} // TODO: Add your control notification handler code here m_bAdd = FALSE; m_bEdit = FALSE; DisplayRecord(); SetButtonState(); SetTextState();

第十二步,在“Query”按钮插入如下事件脚本: void CReaderMDlg::OnEnquery()

{

// TODO: Add your control notification handler code here UpdateData(TRUE); if (m_strReaderIDQ.IsEmpty() && m_strReaderNameQ.IsEmpty()) { } BOOL mAll = FALSE; if (!m_strReaderIDQ.IsEmpty()) { } if (!m_strReaderNameQ.IsEmpty()) { if (mAll) { } m_rsDataSet.m_strFilter = m_rsDataSet.m_strFilter + " AND m_rsDataSet.m_strFilter = m_rsDataSet.m_strFilter + m_rsDataSet.m_strFilter = m_rsDataSet.m_strFilter + "'"; m_rsDataSet.m_strFilter = "READER_ID='" + m_strReaderIDQ ; m_rsDataSet.m_strFilter = m_rsDataSet.m_strFilter + "'"; mAll = TRUE; m_rsDataSet.m_strFilter = ""; m_rsDataSet.Requery(); DisplayRecord(); SetButtonState(); return; NAME='"; m_strReaderNameQ;

} } else { } m_rsDataSet.m_strFilter = "NAME='" + m_strReaderNameQ; m_rsDataSet.m_strFilter = m_rsDataSet.m_strFilter + "'"; m_rsDataSet.Requery(); DisplayRecord(); SetButtonState();

第十三步,在“Delete”按钮插入如下事件脚本:

void CReaderMDlg::OnDelete()

{

} // TODO: Add your control notification handler code here m_rsDataSet.Delete(); DisplayRecord(); SetButtonState();

第十四步,在“Exit”按钮插入如下事件脚本:

void CReaderMDlg::OnExit()

{

} // TODO: Add your control notification handler code here CDialog::OnOK();

到此已经实现了用户登录模块和读者资料维护模块已经实现,这几个模块设计了通过MFC ODBC访问数据库的主要技术细节。其他模块的实现方式与这几个模块类似。余下主要实验源代码见附录。

四、设计的特点和结果

包括实验处理结果和设计心得。指出实验结果运行的操作系统和平台。

参考文献

1、杨小平,VC++项目实践攻关,科学出版社,2002年6月

附录

自己做的主要实验源代码:

更多相关推荐:
图书管理系统设计报告论文

深圳广播电视大学计算机信息管理专业毕业设计论文图书管理系统设计与实现摘要在信息化时代数据库系统的建设实现对数据信息化的管理在此基础上建立了图书管理系统为其信息时代管理和交流提供了极大的便利该论文着重论述了运用v...

图书管理系统详细设计报告(经典范例)

实验报告课程名称软件工程导论课题名称图书管理系统详细设计报告专业计算机科学与技术班级计算机0903学号姓名指导教师20##年5月24日目录1.1编写目的...21.2背景...21.3定义...31.4参考资料…

图书管理系统设计报告

学校图书管理系统的开发图书管理系统系统设计目的和内容图书管理系统主要目的是对图书馆种类繁多的书籍进行管理并且合理管理好用户的借还信息提高图书馆的工作效率降低管理成本其开发主要包括后台数据库的建立和维护以及前端应...

图书管理系统设计报告

图书管理系统设计报告课程信息系统分析与设计班级组别第五组成员李志敏陈奕彤高荣超导师陈广宇080704颜琼赵林宁陈亚楠图书管理系统设计报告一组织情况概述本课题为图书信息管理系统它的主要功能是先通过管理员身份验证然...

图书管理系统总体设计报告

概要设计说明书编写规范项目名称总统设计说明书图书管理系统作者完成日期签收人签收日期概要设计说明书编写规范目录1引言11编写目的112范围113定义114参考资料22总体设计221需求规定222系统环境配置223...

小型图书管理系统设计报告

陕西师范大学远程教育学院题目:java小型图书管理系统设计学习中心:陕西省咸阳教育科技培训学院学号:层次:高中起点专科姓名:1.前言本系统是小型图书管理系统,专为个人设计。本系统启动后需要登陆,然后进入主界在这…

图书管理系统设计报告

软件综合设计实训报告网上图书销售系统院系:计算机科学技术学院班级:软件12-2班姓名:学号:指导教师:20##年1月4日目录一、概述.......................................…

图书管理系统毕业设计报告

图书管理系统院系专业班级学号姓名指导教师负责教师沈阳航空航天大学20xx年5月沈阳航空航天大学毕业实习报告摘要二十一世纪是信息的社会信息作为社会最主要的资源将成为战略资源引起人们广泛的关注如何获取信息图书是我们...

SQL图书管理系统设计课题报告

1SQL图书管理系统设计课题报告班级计网0901班小组成员柳录秧周龙20xx1203目录1图书管理系统ER图2系统功能设计3数据表的创建4数据库完整性设计5SQLServer数据库对象设计21图书管理系统设计E...

图书管理系统_毕业设计论文_目录

毕业设计论文目录摘要引言第一章VisualFoxPro60系统开发基础111主要功能112性能指标113新增功能214常用文件名及其类型2第二章图书管理系统的功能分析设计321系统功能分析322系统模块设计32...

校园图书管理系统设计与实现毕业论文

xx学院xxx届毕业论文设计论文设计题目院系名称专业班级姓名学号指系完基于ASPNET的图书管理系统的设计与实现计算机科学与技术系XxxXxxxxxxxxxxxxxxx20xx421导负成教责时师人间基于ASP...

图书管理系统设计实习报告

实习报告专业:软件工程2班姓名:XX学号:XX指导教师:XX时间:20XX年10月8日目录一图书馆图书借阅管理系统规划1.1绪论(3)1.2图书馆系统分析及功能论述(3)1.3图书借阅系统可行性分析(4)二图书…

图书管理系统设计报告(25篇)