软件设计说明书-图书管理系统
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
图书管理系统
设计说明书
编写:
校对:
审核:
目录
1引言 (1)
2程序系统的结构 (2)
3程序(标识符)设计说明 (2)
4 还书模块 (7)
5 图书查询模块 (11)
6 系统操作模块 (15)
参考资料 (36)
1引言
1. 1目的
根据《需求规格说明书》、《概要设计说明书》,在仔细考虑讨论之后,我们对《图书管理系统》软件的功能划分、数据结构、软件总体结构的实现有了进一步的想法。我们将这些想法记录下来,作为详细设计说明书,为进一步设计软件、编写代码打下基础。
1.2概述
随着社会信息量的与日俱增,作为信息存储的主要媒体之一图书,数量、规模比以往任何时候都大的多,不论个人还是图书管理部门都需要使用方便而有效的方式来管理自己的书籍。在计算机日益普及的今天,对个人而言若采用一套行之有效的图书管理系统来管理自己的书籍,会方便许多。对图书管理部门而言,以前单一的手工检索已不能满足人们的要求,为了便于图书资料的管理需要有效的图书管理软件。
本图书管理系统软件是一套功能比较完善的数据管理软件,具有数据操作方便高效迅速等优点。该软件采用功能强大的数据库软件开发工具进行开发,具有很好的可移植性,可在应用范围较广的DOS、WINDOWS系列等操作系统上使用
1.3定义
文档中采用的专门术语的定义及缩略词简要如下:LMS:Library Management System,图书管理系统
2程序系统的结构
3程序(标识符)设计说明
3.1主模块
建立与数据库连接
获取系统设置
运行主对话框
根据输入调用子模块
退出系统时断开与数据库的连接
●输入项目
用户鼠标点击输入
●程序逻辑
见右图
●存储分配
内部数据:数据库连接m_pConnection _ConnectionPtr 数据库连接指针
m_IsConnected BOOL 数据库连接指示
系统设置m_MaxLBNum int 可借图书数上限
m_MaxLBDay int 借书天数上限
子对话框m_BookOutDlg CBookOutDlg 借书对话框
m_BookInDlg CBookInDlg 还书对话框
m_BookQuiryDlg CBookQuiryDlg 图书查询对话框
m_SysDlg CSysDlg 系统操作对话框
●测试要点
数据库连接情况:正常情况,数据库文件缺少,外部系统异常。
系统设置获取:正常情况,外部系统异常。
对用户输入的响应:合法输入,能够正常调用子模块;
非法输入,系统能否辨别,并作出响应(提出警告);
子模块的异常状况,系统能否及时做出响应。
3.2借书模块
●功能
查验输入的读者证号
运行借书对话框
获取该读者的相关信息
查验输入的图书号
登记借书
●输入项目
读者证号、图书书号(用户输入)
●输出项目
读者信息(姓名);读者已借图书信息(书名、借书日期);
●程序逻辑
查验
●接口
调用形式:void CBookDlg::LendBook(const _ConnectionPtr pConnection,
const int MaxLBNum)
传入参数:pConnection 数据库连接指针
MaxLBNum 系统参数(可借图书上限)
传出参数:无
●存储分配
内部数据:数据库m_pConnection _ConnectionPtr 数据库连接指针
用户界面 m_strReaderName CString 读者姓名
m_strLBInf CString 已借图书信息
m_strLBNum CString 已借图书数
显示
m_lBookID long 欲借图书书号内部参数 m_lReaderID long 当前读者证号
m_MaxLBNum int 可借图书数上限
●测试要点
模块正常运行流程
用户输入数据检查(读者证号、图书书号),包括数据合理性检查,以及合法性检查
数据库操作
数据库连接异常时的响应情况
3.2.1 读者查验模块
●功能
查验输入的读者证号是否合法(即是否存在与该读者证号对应的读者记录)
●输入项目
读者证号(整型常数),读者姓名(引用型字符串)
●输出项目
查验结果(BOOL值)
●程序逻辑
生成数据库查询语句
调用数据库查询模块
IF返回结果集为空(不存在该读者证号)
置读者姓名字符串为空
返回”非法读者证号”
ELSE
置读者姓名字符串
返回”合法读者证号”
●接口
调用形式:BOOL CheckReader(const long ReaderID,CString &strReaderName)
传入参数:ReaderID(常量参数传入) 待查验的读者证号
m_pConnection(借书模块内的全局变量) 数据库连接指针
传出参数:读者证号存在/不存在标志(返回值)
strReaderName(传入的引用参数) 读者证号对应的读者姓名
(读者证号不存在时置为空)
●存储分配
局部变量:数据库pReader _RecordsetPtr 数据库查询结果集指针
查询参数vtQuiry _variant_t 查询命令