数据库课程设计报告酒店客房管理

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

酒店客房管理系统本学期学习了数据库系统概论这门课,初步掌握了数据库的一般性知识,获得了一些基本的数据库操作技能,能够对数据库进行一些简单的操作。结合上星期学习的JAVA基础这门课,本次课程设计将通过Java利用Mysql,MyEclipse来做一个实例练习掌握的知识。一.系统概述1.系统目标采用电脑管理业务、财务等诸多环节已成为推动宾馆业迅速发展的先决条件,宾馆客房管理系统是各大中小型宾馆所需要使用的一个管理系统。建立起一套功能完善的管理信息系统,既能满足业务人员日常处理的需要,增强企业经营全过程的数字化管理水平;又能满足管理人员决策分析的需要,提高公司管理层对公司经营反馈信息的响应速度。本实例将通过使用Mysql,MyEclipse设计软件,帮助酒店客房相关人员快速方便地对客人信息,员工信息进行管理。将原本散乱的客人信息系统化,图形化,建立一个运行稳定,易于操作的酒店客房管理系统,让工作人员能够方便快捷地执行各项工作。2.具体需求1)功能需求系统初始化对系统的基本信息的名称、编号的初始化,对系统管理员的密码以及其他系统使用人员的用户名、权限、密码等的设定。客房信息管理实现房间基本信息的增、删、改、查等的维护工作。支持根据房间状态是预订、入住、空闲等类型进行查询。物品信息管理实现客房日常消耗物品信息的增删改查等维护工作。支持物品存量查询、入库登记、出库登记。员工信息管理实现员工基本信息的增删改查等维护工作。支持员工与入住、结账、物品出入库等活动的登记,做到经手人负责。宾馆入住管理实现客房预订登记,主要是登记客人身份证、手机号码、预订房间类型和天数等基本信息,实现入住登记,即根据登记的客人身份证信息查询到预订的房间,修改房间状态,收取押金,实现房间调整,退房结账。客人消费管理实现客房收费物品、洗衣费、餐饮等服务项目登记,如果超过押金要及时给出预警。最后退房时结算。系统安全管理实现对系统数据库进行备份和恢复的功能,以增强系统可靠性,并对系统用户进行权限管理,以增加系统的安全性。2)性能需求数据精确度:查询时应保证查全率,所有相应域包含查询关键字的记录都应能查到;时间特性:一般操作的响应时间应在1~2s内;适应性:Windows2000以上系统均可运行3)系统安全性一个功能完善的酒店客房管理系统,除了应保证能正常执行功能以外,还要具备一定的数据保护能力,以防止人为破坏或自然破坏。为此,要做到以下内容:要有严格的登录用户身份检查功能,防止非法用户的登录对各用户的操作权限要有严格分工,不能因为分工不清造成数据的不安全或损坏。对用户登录信息进行保护,防止泄露对用户提交的数据进行预先的完整性检查,防止垃圾数据进入数据库。保证对数据库增加、删除、修改等操作的安全执行,保持数据库中各基本表之间的数据完整性。另外还要注意网络安全和物理安全、数据备份等。二.需求分析进行系统功能分析及数据流图分析数据流程分析就是吧数据在组织内部的流动情况抽象出来,舍去了具体组织结构、信息载体、处理工作等,单从数据流动过程来考察实际业务的数据处理模式。数据流程分析主要包括对信息的流动、传递、处理、存储等的分析。酒店客房管理前厅部预定入住调整退房人力资源部员工登记员工入住员工离职采购部新物品添加删除员工物品出入库客房部服务物品项目登记押金预警客人物品出入新服务添加删除DBA操作者信息备份恢复秘钥管理以上为数据流图三.数据库设计数据库结构设计的好坏对应用系统的效率以及实现的效果有很大的影响,一个优秀的数据库结构设计会减少数据库的存储量,数据的完整性和一致性比较高,系统具有较快的响应速度,简化基于此数据库的应用程序的实现等。由于数据库设计的重要性,人们提出了许多数据库结构设计的技术。但是这些设计方法和设计者的工作经验有很大的关系。因此要从根本上解决所有数据库结构设计的问题,需要多实践,在实践中积累经验和教训,最终成为数据库结构设计的专家。1.数据库概念结构设计这一设计阶段是在需求分析的基础上,设计出能够满足用户需求的各种实体,以及它们之间的关系,为后面的逻辑结构设计单下基础。这个阶段不用考虑所采用的数据库管理系统、操作系统类型和机器类型等问题。这阶段可用的工具很多,用的最多的是E-R图,另外还有许多计算机辅助工具,如CASE等可以帮助进行设计。在本次设计中,根据需求分析的结果,对系统中涉及到的数据进行抽象,主要实体有预订,入住,客房,服务项目,客房,库房,员工,员工物品,权限等。据此,画出酒店客房管理系统的实体-联系图,如图所示。预订手机姓名违约金身份证房间类型预订天数是服务项目是房间号服务项目项目总金额项目数量项目单价员工物品是库房物品数量员工号员工号员工号员工是姓名员工号员工房间号月工资是入住当前天数房间号押金应付总金额身份证分房客房房间号备注一天的价格房间状态房间类型2.数据库逻辑结构设计概念结构是独立于实际设计模型的信息结构,必须将其转化为逻辑结构后才能进行数据库应用的设计。也就是要将概念上的结构转化为Mysql数据库系统所支持的实际数据模型。转化原则:一个实体型转化为一个关系模式。实体的属性就是关系的属性,实体的码就是关系的码。实体间的联系:1:1,转换为一个独立的关系模式,或与任意一端的关系模式合并。1:N,转换为一个独立的关系模式,或与N端关系模式合并。M:N,转换为一个独立的关系模式。具有相同码的关系模式可合并。基于以上原则,转换之后的关系模式集为:秘钥信息(用户名,秘钥)注册信息(用户名,密码,用户类型)客人信息:(姓名,身份证,手机)客人预订:(身份证,房间号,房间类型,入住天数,违约金)客人入住:(身份证,房间号,押金,应付总金额,目前入住天数)客房信息:(房间号,房间类型,房间状态,房间价格)员工信息:(姓名,员工号,员工房间号,月工资)库房存储:(物品,物品单价,数量)员工物品:(员工号,物品,数量)服务项目:(服务物品,服务单价)服务登记:(房间号,服务物品,服务数量,服务总价)考虑因素:每张表设置一到两个主键。以客人信息表中的身份证为参照目标,在客人入住表中设置外键。以员工信息表中的员工号,库房存储表中的物品为参照目标,在员工物品表中设置外键。设置3个触发器,实现当向客人预订表中插入数据时,改客房信息中相应客房状态为预订,当向客人入住表插入数据时,改客房信息中相应客房状态为入住,当向客人入住表删除数据时,改客房信息中相应客房状态为空闲。设置触发器,实现当向库房存储表中插入数据时,向服务物品表中插入相应数据。3.数据库物理结构设计根据逻辑模型,为关系模式选择存取方法,并设计关系,索引等数据文件的物理存储结构,如下:/*秘钥信息*/createtable秘钥信息(用户名char(10),秘钥char(10),primarykey(秘钥));/*登录信息*/createtable注册信息(用户名char(10),密码char(10),用户类型char(10),primarykey(用户名));/*客人信息*/createtable客人信息(姓名char(20)notnull,身份证char(20),手机char(16)notnull,primarykey(身份证));/*客人预订*/createtable客人预订(身份证char(20),房间号char(4)notnull,房间类型char(6)notnull,入住天数intnotnull,违约金intnotnull,primarykey(身份证));/*客人入住*/createtable客人入住(身份证char(20),房间号char(4)notnull,押金intnotnull,应付总金额intnotnull,目前入住天数intnotnull,primarykey(身份证),foreignkey(身份证)references客人信息(身份证),check(Pledge=100));/*客房信息*/createtable客房信息(房间号char(4),房间类型char(6)notnull,房间状态char(4)notnull,房间价格intnotnull,primarykey(房间号));/*员工信息*/createtable员工信息(姓名char(20)notnull,员工号char(6),员工房间号char(4),月工资intnotnull,primarykey(员工号));/*库房存储*/createtable库房存储(物品char(30),物品单价intnotnull,数量intnotnull,primarykey(物品));/*员工物品*/createtable员工物品(员工号char(6),物品char(30),数量intnotnull,primarykey(员工号,Item),foreignkey(员工号)references员工信息(员工号),foreignkey(物品)references库房存储(物品),check(数量=0));/*服务项目*/createtable服务项目(服务物品char(30),服务单价intnotnull,primarykey(服务物品));/*服务登记*/createtable服务登记(房间号char(4),服务物品char(30),服务数量intnotnull,服务总价intnotnull,foreignkey(房间号)references客房信息(房间号),foreignkey(服务物品)references服务项目(服务物品),check(服务数量=0));/*插入仓库触发器*/createtrigger插入仓库afterinserton仓库信息foreachrowinsertinto服务项目values(new.物品,new.单价);/*改变客房状态触发器1*/createtrigger改变客房状态1afterinserton预订信息foreachrowupdate客房信息set房间状态='预订'where客房信息.房间号=new.房间号;/*改变客房状态触发器2*/createtrigger改变客房状态2afterinserton入住信息foreachrowupdate客房信息set房间状态='入住'where客房信息.房间号=new.房间号;/*改变客房状态触发器3*/createtrigger改变客房状态3afterdeleteon入住信息foreachrowupdate客房信息set房间状态='空闲'where客房信息.房间号=old.房间号;四.数据库实施在Mysql命令行中输入用户名,密码进入Mysql,在记事本上写一句操作,同时在命令行中运行一句,确保成功。这样也可以利用记事本里的语句段快速重建数据库,以便测试使用。数据库建好,所有表创建完毕后,添加初始化的数据。Mysql中的数据库创建语句与初始化语句见编码部分。五.应用程序设计1.系统功能模块设计在系统功能分析的基础上,设计系统功能模块划分如下图。酒店客房管理系统前厅部客房部人力资源部采购部管理员六.源代码及实现1)Mysql创建数据库以及初始化代码setnamesgbk;createdatabasehotelcharactersetUTF8;usehotel;createtablecode(Usertypechar(10),Codechar(10),primarykey(Code));createtablelogininfo(Usernamechar(10),Passwordchar(10),Usertypechar(10),primarykey(Username));createtableguestinfo(Gnamechar(20)notnull,Idchar(20),Telchar(16)notnull,primarykey(Id));createtablepreorder(Idchar(20),Rnumchar(4)notnull,Rtypechar(6)notnull

1 / 39
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功