




已阅读5页,还剩28页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
摘 要 随着我国经济的迅速发展和假日经济的出现 宾馆酒店业的竞争愈来愈激 烈 要想在竞争中取得优势 必须在经营管理 产品服务等方面提高服务管理 意识 而对酒店的经营状况起决定作用的是酒店的管理 如何利用先进的管理 手段 提高酒店的管理水平 是每一家酒店的管理者所面临的重要课题 简单 的服务标准已经不是制胜的锦囊 只有做到最细微之处才有机会让顾客体会到 酒店服务的优点 而准确 快捷 周全往往就是最基本的成功要素 虽然计算 机管理并不是酒店走向成功的关键元素 但它可以最大限度的为准确 快捷 周全等要素发挥效用提供有力的支持 因此 采用全新的计算机网络和管理系 统 将成为提高酒店的管理效率 改善服务水准的重要手段之一 面对信息时 代的机遇和挑战 利用科技手段提高企业管理无疑是一条行之有效的途径 信 息与科技在酒店管理与现代化建设中显现出越来越重要的地位 在某种意义上 酒店客房状态管理方面的信息化与科学化 已成为现代化酒店的重要标志 系统是在 WindowsXP 的环境下 用 Borland Delphi7 0 开发的信息管理系统 该系统采用模块化设计 根据宾馆前台收银管理系统的实际情况 研究开发的 一套管理系统 宾馆收银管理系统针对我国目前宾馆收银管理现状以及未来的 发展趋势将宾馆收银思想融入其中 充分体现了现代宾馆收银新思想 主要功 能是完成了对大量宾馆收银信息的系统化管理 包括新帐目的录入 对存档数 据的更新 删除 修改 综合查询 帮助等 通过计算机使宾馆收银管理步入 了自动化 科学化管理的行列 避免了以往手工操作等繁杂的劳动 即节省了 人力 又方便快捷 还大大提高数据的准确性 本系统除了对宾馆收银管理系统的各个功能模块作了详细的介绍 还附有 各功能模块的主界面图 在功能叙述过程中配有插图 帮助更好的理解和使用 该系统的功能内容 关键词 客房管理系统 可行性分析 需求分析 概要设计 1 目 录 1 概述 1 2 可行性分析 2 2 1 技术可行性 2 2 1 1 软件可行性 2 2 1 2 硬件可行性 2 2 2 经济可行性 2 2 3 操作可行性 3 3 需求分析 3 3 1 软件生存周期 4 3 2 需求分析的步骤 4 3 2 1 需求信息的收集 4 3 2 2 调查的目的 5 3 2 3 调查的内容 5 3 3 宾馆前台收银管理的目的 5 4 概要设计 6 4 1 宾馆前台收银管理系统的内容 6 4 2 系统设计的意义 6 4 3 开发环境介绍 7 4 4 系统应实现的具体功能 8 4 5 系统功能模块结构图 9 5 详细设计 9 5 1 设计目标 9 5 2 数据库设计 10 5 2 1 数据库概要说明 10 5 2 2 主要数据表结构 10 5 2 3 ER 图绘制 12 5 3 功能模块设计 14 5 4 主窗口设计 16 2 5 4 1 客户区设计 16 5 4 2 菜单设计 17 5 4 3 代码分析 18 5 5 登录模块设计 21 5 5 1 实现目标 21 5 5 2 设计步骤 21 5 5 3 代码分析 23 5 6 住宿管理模块设计 25 5 6 1 实现目标 25 5 6 2 设计步骤 25 5 6 3 代码分析 26 总结 29 参考文献 30 1 1 概述 随着社会发展 人类的生产 生活越来越离不开信息 谁拥有了更多更有 效的信息 谁就将在竞争中处于有利地位 信息产业正在成为一个国家的支柱 数据作为信息的载体 其管理工具数据库对于信息技术的重要性 正日益得到 人们的重视 只有拥有了先进的数据库技术 才能有效地管理好浩如烟海的数 据 并从中提取出对自己有用的信息来加以利用 酒店客房的管理是酒店管理的一个重要的内容都必须切实面对的工作 但一 直以来人们使用传统的人工方式管理酒店 这种管理方式存在着许多缺点 如 效 率低 保密性差且较为烦琐 另外随着客房数量的增加 其工作量也将大大增加 这必然增加客房管理者的工作量和劳动强度 这将给客房管理信息的查找 更 新和维护都带来了很多困难 经过详细的调查 目前我国各类酒店客房中有相当一部分单位客房管理还 停留在人工管理的基础上 尤其是中 小得酒店客房的管理更是如此 这样的 管理机制已经不能适应时代的发展 其管理方法将浪费许多人力和物力 随着 科学技术的不断提高 这种传统的手工管理方法必然被以计算机为基础的信息管 理方法所取代 客房管理作为计算机应用的一个分支 有着手工管理所无法比拟的优点 如 检索迅速 查找方便 可靠性高 存储量大 保密性好 寿命长 成本低等 这些优点能够极大地提高酒店管理的效率 因此 开发一套能够为用户提供充 足的信息和快捷的查询手段的酒店客房管理系统 将是非常必要的 也是十分 及时的 因此可以把宾官客房管理作为设计的题目 宾馆收银管理系统针对我国目前宾馆收银管理现状以及未来的发展趋势将 宾馆收银思想融入其中 充分体现了现代宾馆收银新思想 主要功能是完成了 对大量宾馆收银信息的系统化管理 包括新帐目的录入 对存档数据的更新 删除 修改 综合查询 帮助等 通过计算机使宾馆收银管理步入了自动化 科学化管理的行列 避免了以往手工操作等繁杂的劳动 即节省了人力 又方 便快捷 还大大提高数据的准确性 2 本系统除了对宾馆收银管理系统的各个功能模块作了详细的介绍 还 附有各功能模块的主界面图 在功能叙述过程中配有插图 帮助更好的理解和 使用该系统的功能内容 2 可行性分析 2 1 技术可行性 2 1 1 软件可行性 该软件的开发可以在任何版本 Windows 操作系统下进行 利进行 Delphi7 0 开发 在计算机上只需安装一般的字处理软件和一些支持软件 不需要大型的 系统软件和应用软件来支持 2 1 2 硬件可行性 该系统是一个数据库管理系统 对数据库进行操作只需要奔腾以上处理器 的计算机 内存应该为 32M 以上 有 1G 空余硬盘空间的计算机来开发和运行 该软件 目前 开发者熟悉 Delphi7 0 和 Windows98 操作系统 具有开发大型软件 的能力 综上 开发该管理软件具有技术可行性的 2 2 经济可行性 进行该软件的开发经费和投资较少 开发只需一台奔腾以上的计算机及相 应的软件 该系统的研制和开发充分考虑用户的业务往来 管理流程和人员素质等方 面的因素 从而能够满足使用的要求 窗口操作简单 直观 易于掌握 是具 有运行可行性的 综上所述 开发酒店收银管理系统是可行的 随着信息技术的发展和人们对宾馆酒店的要求越来越高 许多宾馆已明显 觉得手工管理已不能适应当前宾馆高速发展的需要 宾馆已意识到使用计算机 网络和计算机管理的重要性 决定首先在客房部采用宾馆客房管理系统 该系统应充分利用信息技术提高宾馆客房的管理水平 服务水平 宾馆客 房管理系统要实现客房预定 住宿登记 追加押金 调房登记 退房结帐 挂 3 账 查询统计 预收销售报表等功能 其中动态实时的住宿登记 客房调整 销售报表 追加押金等有机的联系在一起 对宾馆客房进行全方位的管理 2 3 操作可行性 在用户登录模块中 分为管理员用户和普通用户 分别赋予不同的权限 管 理员用户可以对数据库进行数据库的日常维护 其中包括数据库信息的查询 修改 插入与删除 以及普通用户的批准 普通用户可以对数据库进行数据信 息的查询 在其它用户管理模块中 主要实现对登陆人员信息的管理 包括姓 名 凭证号 编号和联系方式等信息的管理 在查询模块中实现对客房情况 用户情况等查询 方便对客房入住情况 客户入库情况的查询 并可对用户的 信息进行查询 介于本系统界面清晰 操作简单 查找添加数据方便 易于操作 对于此 系统的可操作性强 3 需求分析 设计一个性能良好的数据库系统 明确应用环境对系统的要求是首要的和 最基本的 特别是数据应用非常广泛 非常复杂 要是事先没有对信息进行充 分和细致的分析 这种设计就很难取得成功 通过需求分析阶段对仓库管理系统的整个应用情况作全面的 详细的调查 确定仓库管理的目标 收集支持系统总的设计目标的基础数据和对这些数据的 要求 确定用户的需求 并把这些写成用户和数据库设计者都能够接受的文档 事实上 需求分析是数据库开发中最难的任务之一 因为 第一 系统本 身是可变的 用户的需求必须不断调整 使之与这种变化相适应 第二 用户 很难说清某部分工作的功能处理过程 所以 设计人员必须认识到 在整个需 求分析以及系统设计过程中 用户参与的重要性 通过各种方法展开调查分析 4 3 1 软件生存周期 需求分析主要是确定宾馆收银管理系统的功能 性能 数据 界面等要求 根据软件生存周期这一思想 可得出软件生存具体包括五个方面的内容 1 制定计划 确定宾馆收银管理系统的总目标 给出它的功能 性能 可 靠性以及接口等方面的要求 同系统分析员和用户合作 研究完成开发宾馆收 银管理系统的可行性 探讨解决问题的可能方案 制定出完成宾馆收银管理系 统的实施计划 2 需求分析和定义 对待宾馆收银管理系统提出的需求进行分析并给出详 细的定义 3 软件设计 设计是软件工程的技术核心 在设计阶段中 设计人员把已 确定了的各项需求转换成一个相应的体系结构 4 程序编写 把宾馆收银管理系统设计转换成计算机可以接受的程序代码 即写成以某一种特定程序设计语言表示的 源程序清单 这一步工作也称为 编码 5 软件测试 测试是保证宾馆收银管理系统软件质量的重要手段 其主要 方式是在设计测试用例的基础上检验宾馆收银管理系统软件的各个组成部分 6 运行及维护 宾馆收银管理系统软件在运行中可能由于多方面的原因 需要对它进行修改 其原因可能有 运行中发现了宾馆收银管理系统软件中的 错误需要修正 为了适应变化了的宾馆收银管理系统软件工作环境 需做适当 变更 为了增强件的功能需做变更 3 2 需求分析的步骤 需求分析大致可分为三步来完成 即需求信息的收集 分析整理和评审通 过 3 2 1 需求信息的收集 需求信息的收集又称为系统调查 为了充分地了解用户可能提出的要求 在调查研究之前 要做好充分的准备工作 要了解调查的目的 调查的内容和 调查的方式 5 3 2 2 调查的目的 首先 要了解组织的机构设置 主要管理活动和职能 其次 要确定组织 的目标 大致管理流程和任务范围划分 因此 宾馆客房管理系统主要是通过对现有的客房管理系统进行考察 研 究 并且通过和酒店客房管理人员 供货商交流来完善管理功能 3 2 3 调查的内容 外部要求 信息的性质 响应的时间 频度和如何发生的规则 以及客房 管理的要求 安全性及完整性要求 管理的现状 即客房管理信息的种类 信息流程 信息的处理方式 各种 客房服务工作过程 组织机构 了解仓库管理机构的作用 现状 存在的问题 及是否适应计 算机管理 3 3 宾馆前台收银管理的目的 在信息高度发达的今天 宾馆收银涉及的各环节已不再仅仅是传统的住宿 结算业务而是更广泛 更全面的服务性行业代表 宾馆作为一个服务性行业 从客房的营销 即客人的预定开始 到入住登记直至最后退房结帐 整个过程 应该能够体现以客人为中心 提供快捷 方便的服务 令客人感受到一种顾客 至上的享受 提高宾馆的管理水平 简化各种复杂操作 在最合理最短时间内 完成宾馆业务规范操作 这样才能令客人舒适难忘 增加客人回头率 面对宾 馆业内激烈的竞争形势 各宾馆均在努力拓展其服务领域的广度和深度 虽然 信息化并不是宾馆走向成功的关键元素 但它可以帮助那些真正影响成败的要 素发挥更大的效用 因此 采用全新的计算机网络和管理系统 将成为提高宾 馆的管理效率 改善服务水准的重要手段之一 现代宾馆前台收银管理和计算机系统结合得非常紧密 很多收银服务的有 效执行和监督都依赖于完善的计算机收银管理系统 其目的是实现宾馆前台收 银管理的系统化 规范化和自动化 6 4 概要设计 软件的开发包括系统分析 系统设计规划 后期编码 软件测试 软件发 布等过程 系统分析是开发一个项目的前提 4 1 宾馆前台收银管理系统的内容 在信息高度发达的今天 宾馆收银涉及的各环节已不再仅仅是传统的住宿 结算业务而是更广泛 更全面的服务性行业代表 宾馆作为一个服务性行业 从客房的营销 即客人的预定开始 到入住登记直至最后退房结帐 整个过程 应该能够体现以客人为中心 提供快捷 方便的服务 令客人感受到一种顾客 至上的享受 提高宾馆的管理水平 简化各种复杂操作 在最合理最短时间内 完成宾馆业务规范操作 这样才能令客人舒适难忘 增加客人回头率 面对宾 馆业内激烈的竞争形势 各宾馆均在努力拓展其服务领域的广度和深度 虽然 信息化并不是宾馆走向成功的关键元素 但它可以帮助那些真正影响成败的要 素发挥更大的效用 因此 采用全新的计算机网络和管理系统 将成为提高宾 馆的管理效率 改善服务水准的重要手段之一 根据宾馆的具体情况 系统主要功能包括 住宿管理模块 包括客房预定 入住登记 客人续住 调房登记 退房 结帐 5 部分 客房管理模块 包括客房设置 客房查询 宿费提醒 3 部分 查询统计模块 包括预定房查询 住宿查询 退宿查询 客房宿费统计 4 部分 报表管理模块 包括预售报表 客房销售报表 2 部分 挂帐管理模块 包括客户管理 挂账查询 客户结帐 3 部分 系统设置模块 包括系统初使化 权限管理 密码设置 3 部分 4 2 系统设计的意义 面对服务行业的高速发展和宾馆企业信息化发展的过程中出现的各种情况 该宾馆收银管理系统在实施后应能够达到以下目标 实现多点操作的信息共享 相互之间的信息传递要准确 快捷 7 采用汉字图形用户界面 系统界面友好美观 操作简单易行 查询灵活方 便 业务管理信息化 可随时掌握客人消费 结帐 挂账等情况 采用多种付款方式 现金 支票 挂账等多种方式混合收银 该软件应尽可能地降低使用者的劳动强度 同时提高工作质量和效率 系统维护方便可靠 具有灵活性 通用性及安全性的特点 4 3 开发环境介绍 Delphi 7 0 是 Borland 公司推出的全新 32 位 Windows 开发工具 该版本继 承了以前版本使用简便 功能强大 效率高等特点 而且它还增强了面向对象 程序设计的功能 是目前使用得最为广泛的优秀应用系统开发工具之一 它整 体上小巧精短 然而其功能却可以和庞大的 Visual C 媲美 它易用 如同 VB PB 被称为第 4 代编程语言 4GL 计算机软件开发有二个体系 一个是使用传统的程序设计语言 比如 C Pascal 和 Basic 等 另一个则是通用的数据库管理软件领域 数据库应用 程序的开发 而作为一个优秀的可视化软件开发环境 Delphi 在继承了传统编 程语言 Object Pascal 和数据库语言的所有功能的基础上 结合了这二个体系的 很多优点 它可以用于传统的算术计算编程 也可以用于 Windows 程序开发 由 Delphi 发展的变体 Kelix 还可以在 Linux 世界里大展身手 更令人称道的是 Delphi 具有强大的数据库应用程序开发功能 利用 Delphi 的数据库手段 甚至 可以不必写一行代码便能够开发出简单的数据库应用程序 Delphi 支持 BDE ODBC ADO 等几种数据引擎 可以访问多种数据格 式 使用 BDE 的 SQL Links 或 ODBC ADO 接口还可以开发客户 服务器体 系的数据库应用系统 Microsoft SQL Server 2000 是微软公司开发的中型关系数据库管理系统 由 于其操作简单 价格相对较低 适用于预算紧张 员工不多的中小企业 由于 SQL Server 2000 与当前 Windows 操作系统有着天然的兼容性 并且该数据库软 件具有友好的操作界面和良好的兼容性 设计后台数据库充分了解用户各个方 8 面的需求 以及考虑到前台开发语言与后台库的衔接要求 最终确定 SQL Server 2000 为毕业设计的数据库系统设计软件 4 4 系统应实现的具体功能 为了适应现代社会人们高度强烈的时间观念 宾馆管理系统软件为管理人 员带来了极大的方便 通过操作手册 使用者可以了解本软件的基本工作原理 操作人员只需输入一些简单的汉字 数字 即可达到自己的目标 对于宾馆来 说 利用计算机支持高效率完成日常事务 是适应现代要求 推动管理走向科 学化 规范化的必要条件 而且宾馆管理又是一项非常烦琐的事情 数量之大 核算极其不便 同时计算机具有手工管理所无法比拟的优点 这些优点能够极 大地提高宾馆管理的效率 也是宾馆的科学化 正规化管理 与世界接轨的重 要条件 根据该企业的具体情况 系统主要功能设计有六大部分 分别为住宿管理 客 房管理 查询统计管理 报表管理 挂账管理 系统设置 面对服务行业的高速发展和宾馆企业信息化发展的过程中出现的各种情况 本系统主要实现如下功能 住宿管理 包括客房预定 入住登记 客人续住 调房登记 退房结帐 5 部分 客房管理 包括客房设置 客房查询 宿费提醒 3 部分 查询统计 包括预定房查询 住宿查询 退宿查询 客房宿费统计 4 部分 报表管理 包括预售报表 客房销售报表 2 部分 挂帐管理 包括客户管理 挂账查询 客户结帐 3 部分 系统设置 包括系统初使化 权限管理 密码设置 3 部分 9 4 5 系统功能模块结构图 系 统 初 始 化 客 房 预 订 住宿 管理 客房 管理 查询 统计 报表 管理 挂账 管理 入 住 登 记 退 房 登 记 调 房 登 记 续 住 登 记 宿 费 提 醒 房 态 查 询 预 订 查 询 退 房 查 询 住 宿 查 询 宿 房 查 询 预 订 报 表 客 房 销 售 查 询 客 房 管 理 客 房 结 账 权 限 管 理 挂 账 查 询 系统 管理 密 码 设 置 房 态 设 置 客房管理系统系统功能图 图 1 宾馆管理系统结构图 5 详细设计 5 1 设计目标 本软件系统使根据实际需求而开发的 完全能够实现宾馆客房信息的管理 运用本系统可以实现以下目标 界面友好 界面设计美观 轻松实现客房信息管理的可视 高效 快捷和方便的管理 数据存储安全可靠 同 Windows 操作系统的无缝结合 使用户无需为软件的移植性烦恼 根据巧妙的权限设置使保证信息安全保密 10 5 2 数据库设计 5 2 1 数据库概要说明 在 SQL Server 2000 数据库中建立名为 myhotel 的数据库 设计如下数据表 checkinregtable checkoutregtable guazhanginfo kfyd regmoneytable roomset ting setability usertalbe 图 2 所示的即为本系统中数据库中的数据表结构图 该数据表结构图包含 系统所有数据表 可以清晰地反应数据库信息 图 2 数据库概要说明 5 2 2 主要数据表结构 数据库中的数据如下 表 1 checkinregtable 住宿登记表 字段名数据类型长度描述 凭证号码nvarchar20客户登记凭证号码 姓名nvarchar50客户姓名 证件名称nvarchar20客户证件 证件号码nvarchar20客户证件号码 详细地址nvarchar50客户详细地址 出差事由nvarchar50客户出差原因 房间号nvarchar20客户房间号 客房类型nvarchar10客户房间类型 联系电话nvarchar20客户联系电话 客房价格money8客户房间价格 住宿日期datetime8客户住宿日期 住宿时间datetime8客户住宿时间 11 住宿天数float8客户住宿天数 宿费money8 折扣float8 应收宿费money8客户应收宿费 预收金额money8客户预收金额 提醒日期datetime8所要求的提醒日期 退宿日期datetime8所要求的退宿日期 备注nvarchar50 标志nvarchar1 日期datetime8操作日期 时间datetime8操作时间 结款方式nvarchar10客户结款方式 退宿时间datetime8客户退宿时间 提醒时间datetime8客户提醒时间 摘要nvarchar200附加摘要 BZfloat8 表 2 roomsetting 客房设置表 字段名数据类型长度描述 房间号nvarchar30 房间类型nvarchar20 价格money8 房态nvarchar4 标志bit1使用标志 备注nvarchar100 配置nvarchar100 使用设置nvarchar10 营业日期smalldatetime4 12 表 3 顾客信息表 字段名列标示类型长度完整性约束 身份证号身份证号 char20 主键 顾客姓名姓名 char8 允许空值 顾客性别性别 char2 允许空值 顾客电话电话 char12 允许空值 入住日期入住日期 datetime8 不允许空值 折扣折扣 smallint2 允许空 表 4 订房信息表 字段名列标示类型长度完整性约束 订房编号订房编号 int4 主键 入住日期入住日期 datetime8 不允许空值 身份证号身份证号 char20 不允许空值 顾客姓名姓名 char8 允许空值 顾客性别性别 char2 允许空值 表 5 房间信息表 字段名列标示类型长度完整性约束 房间编号编号 int4 主键 房间单价单价 money8 不允许空值 是否有空调空调 bit1 允许空值 是否有电视电视 bit1 允许空值 是否有电话电话 bit1 允许空值 是否有独立 卫生间 独立卫生间 bit1 允许空值 表 6 入住信息表 字段名列标示类型长度完整性约束 身份证号身份证号 char20 主键 顾客姓名姓名 char8 允许空值 房间编号编号 int4 不允许空值 入住日期入住日期 datetime8 不允许空值 顾客性别性别 char2 允许空值 13 5 2 3 ER 图绘制 房间 编号 电话 卫生间 可住人 数 单价 电视 空调 图 3 房间实体 属性图 顾客 入住日 期 性别 姓名 身份证 号 电话 折扣 图 4 顾客实体 属性图 订房信息 订房编 号 入住日期折扣 性别 姓名 身份证号 图 5 订房信息实体 属性图 14 身份证 号 姓名 入住日 期 性别 编号 入住信 息 图 6 入住信息实体 属性图 n m 1 1 1 n 房间 入住 订房 结算 顾客 图 7 宾馆信息管理系统综合 E R 图 5 3 功能模块设计 1 利用 Vc 建立一个基于对话框的应用程序 如图 8 所示 在对话框 中输入工程名字和保存目录 点击 确定 按钮 15 图 8 新建 窗口 2 在弹出的步骤 1 对话框中选择基于对话框选项 如图 9 所示 点击 下一步 按钮 图 9 步骤 1 窗口 3 以下步骤保持默认选择 直到完成 16 5 4 主窗口设计 主程序界面是应用程序提供给用户访问其他功能模块的平台 根据实际需 要 物流综合管理系统的主界面采用了传统的 菜单 工具栏 状态栏 风格 物流综合管理系统主程序界面如图 10 所示 图 10 主程序运行界面 5 4 1 客户区设计 在生成的对话框内添加图片 静态文本 标签 编辑框 按钮等资源 设 置主要资源属性如下表所示 控件的属性和 ID 见如表 7 所示 表 7 控件的属性和 ID 控件 ID标题 ID BTN borrowroom开房 ID BTN returnroom结帐 ID BTN mainfind查询 ID BTN daysummery日结 ID BTN alert月结 ID CLOSE退出 17 5 4 2 菜单设计 1 点击 insert Resourse 打开添加资源界面如下图 11 所示 图 11 Insert Resourse 窗口 2 选择 Menu 点击 New 插入空白菜单 设置 ID 属性为 IDR mainMENU 然后按照图 12 编辑菜单项 图 12 菜单资源 主菜单的各个子菜单的 ID 和标题属性如表 8 所示 表 8 各个子菜单的 ID 和标题属性 控件 ID标题 ID MENU checkinreg住宿登记 ID MENU roomsetting客房设置 ID MENU checkout退宿结帐 ID MENU addmoney追加押金 18 ID MENU changeroomreg调房登记 ID MENU findroom客房查询 ID MENU findguazhang挂帐查询 ID MENU guazhangmoney客户结款 ID MENU findcheckinreg住宿查询 ID MENU findcheckoutreg退宿查询 ID MENU findroomfee宿费提醒 ID MENU regmoneytable登记预收报表 ID MENU saleroomtable客房销售报表 ID MENU saleroomsummary客房销售统计 ID MENU adm setting操作员设置 ID MENU pwd setting密码设置 ID MENU setting begin初始化 ID MENU setting ability权限设置 ID MENU findroomstate房态查看 ID MENU roomprebook客房预定 ID MENU findprebookroom预定房查询 5 4 3 代码分析 1 系统主界面操作可以根据用户的权限设定 所以要加入连接数据库功 能 故在 stdafx h 文件中加入以下代码 提供加入 ADO 的支持 add the support of ADO import c program files common files system ado msado15 dll no namespace rename EOF adoEOF 并在 Myhotel h 中加入 CDatabase m DB ConnectionPtr m pConnection 此外在 myhotel cpp 的初始化函数中加入连接数据库的代码 ry 连接数据库 19 CString strConnect strConnect Format DSN myhotel if m DB OpenEx strConnect CDatabase useCursorLib AfxMessageBox Unable to Connect to the Specified Data Source return FALSE catch CDBException pE 抛出异常 pE ReportError pE Delete return FALSE 初始化 COM 创建 ADO 连接等操作 AfxOleInit m pConnection CreateInstance uuidof Connection 在 ADO 操作中建议语句中要常用 try catch 来捕获错误信息 try 打开本地数据库 m pConnection Open Provider MSDASQL 1 Persist Security Info False Data Source myhotel adModeUnknown catch com error e 抛出可能发生的异常 AfxMessageBox 数据库连接失败 确认数据库配置正确 return FALSE 2 此主窗口初始化时候要根据登录的操作员的权限来设置登录操作员所 有权进行的操作 此功能由函数 setuserability 来完成 代码为 void CMyhotelDlg setuserability m pRecordset CreateInstance uuidof Recordset variant t var varIndex loguserid 操作员 01 CString strsqlshow strsqlshow Format SELECT FROM setability where 操作员 s loguserid 20 try 打开数据库连接 m pRecordset Open variant t strsqlshow 查询表中所有字段 theApp m pConnection GetInterfacePtr 获取库接库的 IDispatch 指针 adOpenDynamic adLockOptimistic adCmdText var m pRecordset GetCollect 初始化 if var vt VT NULL if LPCSTR bstr t var ling 判断是否有权限操作初始化模块 如果没有权利就使该菜单灰显 EnableMenuItem mynenu m hMenu ID MENU setting begin MF DISABLED MF GRAYED 读取数据表内权限设置字段内容 var m pRecordset GetCollect 权限设置 if var vt VT NULL if LPCSTR bstr t var ling 判断是否有权限操作权限设置模块 如果没有权利就使该菜单灰显 EnableMenuItem mynenu m hMenu ID MENU setting ability MF DISABLED MF GRAYED mynenu Detach DrawMenuBar 重绘主菜单 catch com error e 捕获异常 AfxMessageBox e ErrorMessage m pRecordset Close 关闭记录集 m pRecordset NULL 剩余代码省略 21 5 5 登录模块设计 5 5 1 实现目标 为了防止非法用户进入系统 本软件设计了系统登录窗口 在程序启动时 首先弹出登录窗口 要求用户输入登录信息 如果用户输入不合法 将禁止进 入系统 系统登录窗口运行结果下图 13 所示 图 13 登录窗口 5 5 2 设计步骤 图 14 Insert Resourse 窗口 1 点击 insert Resourse 打开添加资源界面如图 10 所示 选择 Dialog 点击 New 插入新的对话框 22 2 利用类向导为此对话框资源设置属性 在 Name 编辑框中输入窗口 类名 例如 CLoginDlg 在 Base class 组合框中选择一个基类 这里为 CDialog 单击 OK 按钮创建窗口 3 在工作区的资源视图中选择新创建的窗口 向窗口中添加静态文本 列表框 编辑框 按钮等资源 设置主要资源属性如表 9 所示 表 9 资源属性 控件 ID对应变量 标题属性 IDC COMBO usernamem username IDC passwordm password IDOK确定 IDCANCEL取消 4 然后建立和数据库的映射 利用类向导建立记录集的映射类 如图 15 所示 图 15 新建类 窗口 选择基类为 CRecordset 点击 OK 按钮进入下一步 如下图 16 所示 23 图 16 Database Option 窗口 选择数据源类型为 ODBC 并选择所使用的数据源 在此选择我们使用的 myhotel 数据源 点击 OK 进入下一步 如图 17 所示 图 17 Select Database Tables 选择所要关联的数据表 因为是操作员登录信息 所以用户表 dbo usertable 数据表 点击 OK 完毕 5 5 3 代码分析 1 可以看到我们已经创建了一个新类 CUserset 其头文件的关键代码如 下 24 class CUserset public CRecordset public CUserset CDatabase pDatabase NULL DECLARE DYNAMIC CUserset Field Param Data AFX FIELD CUserset CRecordset CString m user name CString m user pwd AFX FIELD Overrides ClassWizard generated virtual function overrides AFX VIRTUAL CUserset public virtual CString GetDefaultConnect Default connection string virtual CString GetDefaultSQL Default SQL for Recordset virtual void DoFieldExchange CFieldExchange pFX RFX support AFX VIRTUAL Implementation ifdef DEBUG virtual void AssertValid const virtual void Dump CDumpContext endif 剩余代码省略 2 点击 确定 按钮可以登录到系统主界面 此按钮的相应函数为 if style 25 pMsg wParam VK TAB 重载回车键盘消息为 table 键盘消息 ok return CDialog PreTranslateMessage pMsg 剩余代码省略 5 6 住宿管理模块设计 住宿管理模块包括 客房预定 住宿登记 追加押金 调房登记 退宿结帐 等功能子模块 下面详细介绍客房预定子模块设计 5 6 1 实现目标 此模块实现客房预定的功能 主要登记用户的姓名 证件 证件号码 预 住日期等信息 是为预定客户提供的方便模块 运行界面如图 18 所示 图 18 客房预定 窗口 5 6 2 设计步骤 1 点击 insert Resourse 打开添加资源界面 选择 Dialog 点击 New 插入新的对话框 2 利用类向导为此对话框资源设置属性 在 Name 编辑框中输入窗口 类名 例如 CRoomprebookdlg 在 Base class 组合框中选择一个基类 这里为 CDialog 单击 OK 按钮创建窗口 26 3 在工作区的资源视图中选择新创建的窗口 向窗口中添加静态文本 列表框 编辑框 按钮和日期选择控件等资源 设置主要资源属性如表所示 各个主要控件的 ID 和属性设置如表 10 所示 表 10 控件的 ID 和属性 控件 ID变量 IDC COMBOprebookidkindm prebookidkind IDC COMBOroomkindm prebookroomkind IDC DATETIMEPICKERprecheckindatem prebookcheckindate IDC prebookaddrm prebookaddr IDC prebookdaysm prebookdays IDC prebookhandinmoneym prebookhandinmoney IDC prebookidnumberm prebookidnumber IDC prebooknamem prebookname IDC prebooktelnumberm prebooktelnumber IDC prebookworkcompanym prebookworkcompany IDC roommoneym prebookroommoney IDC STATICshowuserm showuser 5 6 3 代码分析 1 在其对应的头文件 Roomprebookdlg h 里面添加以下声明代码 CString gustname CString gustaddr CString zhengjian CString zhengjian number CString checkinreg reason ConnectionPtr m pConnection CommandPtrm pCommand RecordsetPtrm pRecordset 2 确定预定客房点击 确定 按钮 完成向数据库中插入预定记录 其响 应函数为 27 void CRoomprebookdlg OnOK TODO Add extra validation here UpdateData true 检查身份证的号码是否为 15 位或者为 18 位 CString strCertifyCode 证件号码 获得证件号
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年事业单位工勤技能-湖南-湖南放射技术员二级(技师)历年参考题库典型考点含答案解析
- 2025年事业单位工勤技能-湖南-湖南地图绘制员四级(中级工)历年参考题库含答案解析
- 2025年事业单位工勤技能-湖南-湖南下水道养护工四级(中级工)历年参考题库典型考点含答案解析
- 2025年事业单位工勤技能-湖北-湖北热处理工五级(初级工)历年参考题库典型考点含答案解析
- 2025年事业单位工勤技能-湖北-湖北家禽饲养员三级(高级工)历年参考题库典型考点含答案解析
- 2025-2030中国纳迪克酸酐行业运营格局及投资盈利预测报告
- 低碳城市规划与绿色建筑设计2025年创新案例分析
- 2025年事业单位工勤技能-河南-河南造林管护工二级(技师)历年参考题库典型考点含答案解析
- 2025年事业单位工勤技能-河南-河南园林绿化工三级(高级工)历年参考题库典型考点含答案解析
- 2025年事业单位工勤技能-河南-河南保安员二级(技师)历年参考题库典型考点含答案解析
- PICC常见并发症的预防及处理
- 葫芦岛打渔山 220kV 输变电工程环评报告
- 08SG213-1 钢烟囱(自立式30m-60m)(不清晰有水印)
- 社会团体单位会员登记表完整
- 派出所实习报告PPT模板下载
- GB/T 7757-2009硫化橡胶或热塑性橡胶压缩应力应变性能的测定
- 智能客服趋势发展白皮书:智能客服预见未来课件
- 2009-2022历年江苏省镇江市丹阳市事业单位考试《综合知识和能力素质(计算机类岗位)》真题含答案2022-2023上岸必备带详解版3
- 工业园区消防安全标准化
- 项目造价咨询计划表
- 人教版高中化学必修一离子方程式双线桥单线桥专项练习
评论
0/150
提交评论