- 1、本文档共11页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
目录
1 概述 1
1.1 软件开发环境、工具和方法 1
1.2 软件功能简介 1
2 软件功能设计 2
2.1 系统的总体功能描述 2
3 编码设计 3
3.1 数据库操作 3
3.2 主要模块实现 6
4 测试 9
4.1 黑盒测试 9
4.2 白盒测试 10
5 总结 12
参考文献 13
1 概述
1.1 软件开发环境、工具和方法
宾馆客房管理系统与一般系统的使用方法相似,它是一个应用程序,它运行于Windows的操作平台上;本系统对运行环境无特殊要求,适用于Windows XP操作系统。
宾馆客房管理系统是应用Visual Studio 2005开发环境,整个设计是通过MFC语言编写的,它的设计思想符合软件开发的要求,它是通过一种可视化语言编写的,它的界面设计是通过Visual Studio 2005的控件来实现的,设计过程中的一部分功能程序的编写是通过SQL语句实现的。
本系统以Access 2003做后台数据库,以MFC做前台应用程序。
1.2 软件功能简介
⑴ 不同的用户拥有不同的权限,系统根据用户权限,进入不同的功能界面。权限分为两类:一个是后台管理者权限,一个是前台接待员权限。普通员工无权登陆此系统
⑵ 对宾馆客房的预定、入住、退房等信息进行管理
⑶ 可以以图形方式显示客房入住率、预订率、空闲率
⑷ 后台管理者可以对客房、员工的信息进行管理和查看,可以设置员工的权限,可以查看客房使用情况的图形显示,还可以查询统计预定和退房情况
⑸ 对新增用户,系统默认密码为000000
⑹ 用户登录系统后,可根据自己的需要修改登录密码
⑺ 前台接待员可为顾客进行入住、预定、退房、调房、退订登记
⑻ 前台接待员可以查看客房、宾客信息,可以查看客房使用情况的图形显示,还可以查看统计入住、预定和退房记录
⑼ 前台接待员可根据入住情况(入住延期或由预定转为入住),对顾客追加押金
⑽ 此系统为前台接待员提供了今日提醒功能,包括当天入住到期提醒和预定到期提醒
2 软件功能设计
2.1 系统的总体功能描述
该阶段的主要任务是确定系统必须完成哪些工作,需要完成的具体功能,如图1所示图1 系统功能图
3 编码设计
3.1 数据库操作
⒈ 数据库连接
HRESULT hr;
try
{
hr = m_pConnection.CreateInstance(ADODB.Connection);///创建Connection对象
if(SUCCEEDED(hr))
{
hr=m_pConnection-Open(Provider=Microsoft.Jet.OLEDB.4.0;Data Source=E:\StaffInfo.mdb,,,adModeUnknown);
/*打开连接*/
}
}
catch(_com_error e)///捕捉异常
{
CString errormessage;
errormessage.Format(TEXT(连接数据库失败!\r\n错误信息:%s),e.ErrorMessage());
AfxMessageBox(errormessage);///显示错误信息
}
⒉ 查询数据库
TCHAR c_Remind[256];
GetDlgItemText(IDC_CUS_START,c_Remind,sizeof(c_Remind)/sizeof(TCHAR));///得到空间中的内容
CString temp=c_Remind;
CString tep; ///连接字符串,使用SQL语句进行查询
tep.Format(TEXT(SELECT * FROM customerinfo WHERE cus_endlive=%s AND cus_housenum IN (SELECT house_num FROM houseinfo WHERE house_state=入住)),temp);
m_pRecordset.CreateInstance(ADODB.Recordset);
m_pRecordset-Open(tep.GetBuffer(), ///打开数据库中表
_variant_t((IDispatch*)m_pConnection,true),
adOpenStatic,adLockOptimistic,adCmdText);
tep.ReleaseBuffer();
m_success = TRUE;
if (!m_pRecordset-BOF)///判断查询结果是否为空
{
m_pRe
文档评论(0)