ImageVerifierCode 换一换
格式:DOCX , 页数:20 ,大小:778.19KB ,
资源ID:6164333      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/6164333.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(数据库原理及应用课程设计报告酒店管理系统.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

数据库原理及应用课程设计报告酒店管理系统.docx

1、数据库原理及应用课程设计报告酒店管理系统湖南文理学院芙蓉学院数据库原理及应用 课程设计报告题 目: 酒店管理系统 学生姓名: 学 号: 专业班级: 同组姓名: 指导教师: 设计时间: 指导老师意见:评定成绩: 签名: 日期:一、需求分析 . . . . 3二、系统运行环境 . . 3三、功能需求描述 . .3四、模块结构图 . 4五、数据库设计 . 45.1数据库分析 . 45.2数据库概念设计 . . 45.3 数据库逻辑结构设计 . . 55.4 数据库字典 . . . 7六、程序模块设计 . 66.1功能模块设计. . . 96.2界面设计 . . . . . 106.3程序运行. .

2、. . 11七、模块的实现. . . . .127.1 JDBC数据库连接部分 . . . . . . . . . . . .137.2 开台、点餐功能的实现 . . . . . . . . . . .157.3 结账功能的实现 . . .19八、总结 . 22一、需求分析 随着餐饮行业的迅速发展现有的人工管理方式已经不能满足管理者的需求,广大餐饮业经营者已经意识到使用计算机应用软件的重要性,决定在餐饮企业的经营管理上引入计算机应用软件管理系统。 酒店管理系统的大致功能:1.开台点餐2.自动结账3.菜品管理4.后台菜系菜品管理5.日月年结账报表6.用户设置 本系统采用的语言 (1)本系统采用J

3、ava语言,Java是目前使用最为广泛的计算机语言之一。它具有简单面向对象、稳定、与平台无关等特点。说他简单并不是说这门语言很干瘪、而是一种清楚更容易理解的方式实现程序。面向对象是基于对象的变成更符合人的思维方式使人们更容易编写程序。(2)本系统还采用SQL语言SQL Server具有许多显著优点、易用性、适合分布组织的可伸缩性、用于决策支持的数据仓库功能、与许多其他服务器软件紧密关联的集成性、良好的性价比等。(3)本系统有效的利用Java和SQL的优点。 二、系统运行环境 操作系统为Windows 8、windows 7或windows XP 使用的集成开发工具Eclipse 数据库采用SQ

4、L Server2008项目运行环境为JDK 8。 三、功能需求描述 1开台签单工作区的功能:主要功能有开台、点菜、加菜、签单、查看开台信息和签单信息。2.自动结账工作区的功能:一个功能是自动计算当前选中餐台的消费金额,另一个功能是在结账时自动计算找零金额。 3.结账报表工作区功能:日结帐报表、月结账报表、年结账报表。4.后天管理工作区功能:管理添加信息。四、模块结构图模块结构图五、数据库设计5.1数据库分析酒店管理系统的需求包括开台点菜功能、智能化获取菜品功能、自动结账功能、营业额报表功能等。主要涉及的数据表包括台号表、菜品表、消费单表,为了使系统更加的完善还需要为菜品分类,即需要用到菜系表

5、;为了实现菜品的日销售情况统计,还要建立一个消费项目表,用来记录消费单消费的菜品。 5.2数据库概念设计数据库设计是系统设计过程中的重要组成部分,它是通酒店管理程序设计,通过管理系统的整天需求而制定的,数据库设计的好坏直接影响到系统的后期开发。 5.3 数据库逻辑结构设计(1)餐台和菜系在本系统中的最简单的实体,在本系统中用来描述餐台信息的只有台号和座位数,而描述菜系的主要是名称。餐台信息表(tb_desk)和菜系信息表(tb_sort)的E-R图如下。餐台信息表的E-R图菜系信息表的E-R图(2)在描述菜品实体时加入了助记码,目的是为了实现智能化获取菜品功能。通过这一功能,系统操作员可以快速

6、的获取顾客所点的菜品信息。菜品信息表(tb_menu)的E-R图如图所示。菜品信息表的E-R图(3)消费单信息表(tb_order_form)用来记录每次消费的相关信息,例如消费时使用的餐台、时间、金额等。消费单信息表的E-R图如图所示。消费信息表的E-R图(4)消费项目信息表(tb_order_item)用来记录每个消费单消费的菜品,记录的主要信息有所属消费单、消费菜品、消费数量、消费额。消费项目信息表E-R图如图所示。消费项目信息表的E-R图(5)管理员信息表(tb_manager)用来记录系统的管理员的账号、密码、权限等信息。管理员信息表E-R图如图所示。管理员信息表的E-R图(6)员工

7、信息表(tb_record)用来记录职工的信息,编号、姓名、性别、出生日期、地址等等。职工信息表E-R图如图所示。员工信息表的E-R图5.4 数据库字典5.4.1.餐台信息表表名tb_desk序号字段名数据类型约束备注1numvarchar(6)非空台号2seatingint非空座位数3statechar(4)非空状态5.4.2.管理员表表名tb.manager序号字段名数据类型约束备注1idint非空编号2record_numchar(9)非空用户名3passwordvarchar(20)非空登陆密码4purview_systemchar(2)允许空系统维修权限5purview_sellch

8、ar(2)允许空销售统计权限6purview_personnelchar(2)允许空人员管理权限7purview_initchar(2)允许空初始化系统权限5.4.3.菜品信息表表名tb.menu序号字段名数据类型约束备注1numchar(9)非空编号2sort_idint非空所属菜系3namevarchar(20)非空名称4codevarchar(10)非空主机名5unitvarchar(4)非空单位6unit_priceint非空单价7statechar(4)非空状态5.4.4.消费单信息表表名tb_order_form序号字段名数据类型约束备注1numchar(11)非空编号2Desk_

9、numvarchar(6)非空消费餐台3Consume_datedatetime非空消费时间4expenditureint非空消费金额5Record_numchar(9)非空操作用户5.4.5.消费项目信息表表名tb_order_item序号字段名数据类型约束备注1idint非空编号2Order_form_numchar(11)非空所属消费单3Menu_numchar(9)非空消费菜品4amountint非空消费数量5totalint非空消费额5.4.6.员工表表名tb_record序号字段名数据类型约束备注1numchar(9)非空编号2namevarchar(8)非空员工姓名3sexcha

10、r(2)非空性别4birthdaydatetime非空出生日期5Id_cardvarchar(20)非空身份证号6addressvarchar(100)非空地址7statechar(4)非空状态5.4.7.菜系信息表表名th.sort序号字段名数据类型约束备注1idint非空序号2namevarchar(20)非空名称3statechar(4)非空状态六、程序模块设计6.1功能模块设计:6.2界面设计:登入界面设计管理员界面设计6.3程序运行:登入界面管理界面管理员界面七、模块的实现7.1 JDBC数据库连接部分package com.mwq.dao;import java.sql.Conne

11、ction;import java.sql.DriverManager;import java.sql.SQLException;public class JDBC private static final String DRIVERCLASS = com.microsoft.sqlserver.jdbc.SQLServerDriver; private static final String URL = jdbc:sqlserver:/localhost:1433;DatabaseName=db_DrinkeryManage; private static final String USER

12、NAME = luojie; private static final String PASSWORD = 123456; private static final ThreadLocal threadLocal = new ThreadLocal(); static / 在静态代码块中加载数据库驱动 try Class.forName(DRIVERCLASS).newInstance();/ 加载数据库驱动 catch (Exception e) System.out.println(数据库连接不成功); e.printStackTrace(); public static Connecti

13、on getConnection() / 创建数据库连接的方法 System.out.println(数据库连接成功); Connection conn = threadLocal.get();/ 从线程中获得数据库连接 if (conn = null) / 没有可用的数据库连接 try conn = DriverManager.getConnection(URL, USERNAME, PASSWORD);/ 创建新的数据库连接 threadLocal.set(conn);/ 将数据库连接保存到线程中 catch (SQLException e) e.printStackTrace(); re

14、turn conn;/ 返回数据库连接 public static boolean closeConnection() / 关闭数据库连接的方法 boolean isClosed = true;/ 默认关闭成功 Connection conn = threadLocal.get();/ 从线程中获得数据库连接 if (conn != null) / 数据库连接可用 threadLocal.set(null);/ 清空线程中的数据库连接 try conn.close();/ 关闭数据库连接 catch (SQLException e) isClosed = false;/ 关闭失败 e.prin

15、tStackTrace(); return isClosed;/ 返回关闭结果 7.2 开台点餐功能的实现7.2.1 台号选择框的创建 numComboBox = new JComboBox(); / 创建台号选择框 numComboBox.setNextFocusableComponent(codeTextField); / 设置下一个将要获得焦点的组件 initNumComboBox(); / 初始化台号选择框 numComboBox.addActionListener(new ActionListener() public void actionPerformed(ActionEvent

16、 e) int rowCount = rightTable.getRowCount(); / 获得已开台数 if (rowCount = 0) / 没有开台 return; / 不执行任何操作 Object selectedDeskNum = numComboBox.getSelectedItem(); / 获得“台号”选择框中的选中项 int needSelectedRow = -1; / 默认选中的台号未开台 for (int row = 0; row rowCount; row+) / 查看选中的台号是否已经开台 if (selectedDeskNum.equals(rightTable

17、.getValueAt(row, 1) / 已经开台 needSelectedRow = row; / 保存其在“开台列表” 中的所在行 break; / 跳出循环 if (needSelectedRow = -1) / 选中的台号尚未开台,即将要开台 rightTable.clearSelection(); / 取消选择“开台列表”中的选中行 leftTableDataV.removeAllElements(); / 清空“签单列表”中的所有行 leftTableModel.setDataVector(leftTableDataV, leftTableColumnV); / 刷新“签单列表”

18、表格模型的数据 else / 选中的台号已经开台,即将要添加消费项目 rightTable.setRowSelectionInterval(needSelectedRow);/ 在“开台列表”中选中该台号 leftTableDataV.removeAllElements(); / 清空“签单列表”中的现有项目 leftTableDataV.addAll(itemOfDeskV.get(needSelectedRow); / 向“签单列表”添加新选中餐台的消费项目 leftTableModel.setDataVector(leftTableDataV, leftTableColumnV); /

19、刷新“签单列表”表格模型的数据 leftTable.setRowSelectionInterval(0); / 选中“签单列表”中的第一行 );7.2.2开单功能的实现final JButton addButton = new MButton(); addButton.setIcon(new ImageIcon(TipWizardFrame.class .getResource(/img/main_add.png); addButton.setRolloverIcon(new ImageIcon(TipWizardFrame.class .getResource(/img/main_add_o

20、n.png); addButton.addActionListener(new ActionListener() public void actionPerformed(ActionEvent e) makeOutAnInvoice(); codeTextField.requestFocus(); ); orderDishesButtonPanel.add(addButton); orderDishesPanel.add(numComboBox);7.2.3签单功能的实现final JButton subButton = new MButton();/ 创建按钮 subButton.setIc

21、on(new ImageIcon(getClass().getResource( /img/main_sub.png);/ 按钮默认时显示的图片 subButton.setRolloverIcon(new ImageIcon(getClass().getResource( /img/main_sub_on.png);/ 光标移入时显示的图片 subButton.addActionListener(new ActionListener() public void actionPerformed(ActionEvent e) int selectedRow = rightTable.getSele

22、ctedRow();/ 获得“开台列表”中的选中行 if (selectedRow = 0; row-) leftTable.setValueAt(, row, 0);/ 签单 else / 为已签单项目,即为新添加菜品签单 for (int row = lastRowIndex; row = 0; row-) if (leftTable.getValueAt(row, 0).equals(NEW)/ 为未签单项目 leftTable.setValueAt(, row, 0);/ 签单 else / 为已签单项目,即为新添加菜品签单完成 break; ); orderDishesButtonP

23、anel.add(subButton);7.3 结账功能的实现final JButton checkOutButton = new JButton(); checkOutButton.setText(结 账); checkOutButton.addActionListener(new ActionListener() public void actionPerformed(ActionEvent e) int selectedRow = rightTable.getSelectedRow(); if (selectedRow 0) / 未选中任何餐台 JOptionPane.showMessa

24、geDialog(null, 请选择要结账的餐台!, 友情提示, JOptionPane.INFORMATION_MESSAGE);/ 弹出提示 return; int rowCount = leftTable.getRowCount();/ 获得结账餐台的点菜数量 if (leftTable.getValueAt(rowCount - 1, 0).equals(NEW) / 存在未签单菜品 JOptionPane.showMessageDialog(null, 请先确定未签单商品的处理方式!, 友情提示, JOptionPane.INFORMATION_MESSAGE);/ 弹出提示 ret

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1