点餐
思路分析
多一个模块,同理,根据分层设计,编写相关的类,逐层调用
(1)domain 类(javabean)
(2)dao
(3)service 层
(4)view:用户界面层
点餐逻辑
(1)生成账单
(2)更新餐桌状态(数据库操作)
创建菜单表
sql
#账单流水, 考虑可以分开结账, 并考虑将来分别统计各个不同菜品的销售情况
create table bill (
id int primary key auto_increment, #自增主键
billId varchar(50) not null default '',#账单号可以按照自己规则生成 UUID
menuId int not null default 0,#菜品的编号, 也可以使用外键
nums SMALLINT not null default 0,#份数
money double not null default 0, #金额
diningTableId int not null default 0, #餐桌
billDate datetime not null ,#订单日期
state varchar(50) not null default '' # 状态 '未结账' , '已经结账', '挂单'
)charset=utf8;Bill
java
package domain;
import java.util.Date;
/**
* ClassName: Bill
* Package: domain
* Description:
*
* @author jacksonling
* @version 1.0
* @Date 2025-08-07 19:54
*/
public class Bill {
private Integer id;
private String billId;
private Integer menuId;
private Integer nums;
private Double money;
private Integer diningTableId;
private Date billDate;
private String state;
public Bill() {
}
public Bill(Integer id, String billId, Integer menuId, Integer nums, Double money, Integer diningTableId, Date billDate, String state) {
this.id = id;
this.billId = billId;
this.menuId = menuId;
this.nums = nums;
this.money = money;
this.diningTableId = diningTableId;
this.billDate = billDate;
this.state = state;
}
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getBillId() {
return billId;
}
public void setBillId(String billId) {
this.billId = billId;
}
public Integer getMenuId() {
return menuId;
}
public void setMenuId(Integer menuId) {
this.menuId = menuId;
}
public Integer getNums() {
return nums;
}
public void setNums(Integer nums) {
this.nums = nums;
}
public Double getMoney() {
return money;
}
public void setMoney(Double money) {
this.money = money;
}
public Integer getDiningTableId() {
return diningTableId;
}
public void setDiningTableId(Integer diningTableId) {
this.diningTableId = diningTableId;
}
public Date getBillDate() {
return billDate;
}
public void setBillDate(Date billDate) {
this.billDate = billDate;
}
public String getState() {
return state;
}
public void setState(String state) {
this.state = state;
}
@Override
public String toString() {
return id +
"\t\t" + menuId +
"\t\t\t" + nums +
"\t\t\t" + money +
"\t\t" + diningTableId +
"\t\t\t" + billDate +
"\t\t\t" + state ;
}
}BillDao
java
package dao;
/**
* ClassName: BillDao
* Package: dao
* Description:
*
* @author jacksonling
* @version 1.0
* @Date 2025-08-07 19:55
*/
public class BillDao extends BasicDao<Bill>{
}更新 MenuService
提供 getMenuById( ) 方法,根据菜品 id 返回一个菜品对象,供 BillService 调用,结合点餐份数,计算点餐产生的账单金额,保存到数据库中
java
package service;
import dao.MenuDao;
import domain.Menu;
import java.util.List;
/**
* ClassName: MenuService
* Package: service
* Description:
*
* @author jacksonling
* @version 1.0
* @Date 2025-08-06 18:35
*/
public class MenuService {
//定义MenuDAO 属性
private MenuDao menuDao = new MenuDao();
//返回所有的菜品,在界面层调用
public void listMenu(){
List<Menu> menus = menuDao.queryTable("select * from menu", Menu.class);
System.out.println("\n菜品编号\t\t菜品名\t\t类别\t\t价格");
for (Menu menu : menus) {
System.out.println(menu);
}
System.out.println("==============显示完毕============");
}
// 被 BillService 调用,用于返回菜品对象,计算价格
public Menu getMenuById(int id) {
return menuDao.queryLine("select * from menu where id = ?", Menu.class, id);
}
}更新 DiningTableService
提供 updateDiningTableState( ) 方法,在点完餐后及时更新餐桌状态为 " 就餐中 "
java
package service;
import dao.DiningTableDao;
import domain.DiningTable;
import utils.Utility;
import java.util.List;
/**
* ClassName: DiningTableService
* Package: service
* Description:
*
* @author jacksonling
* @version 1.0
* @Date 2025-08-06 16:21
*/
public class DiningTableService {
// 创建 Dao 对象
private DiningTableDao diningTableDao = new DiningTableDao();
// 编写方法,返回所有餐桌状态并显示
public void listDiningTale(){
List<DiningTable> diningTables = diningTableDao.queryTable("select id, state from diningTable", DiningTable.class);
System.out.println("\n餐桌编号\t\t餐桌状态");
for (DiningTable diningTable : diningTables) {
System.out.println(diningTable);
}
System.out.println("==============显示完毕============");
}
/*
餐桌预定的前提条件
(1)预定的餐桌编号存在
(2)餐桌状态为空
*/
// 接收用户输入,根据 id 返回 DiningTable 对象,在界面层判断是否为空进而判断餐桌是否存在
public DiningTable getDiningTableById(int id){
return diningTableDao.queryLine("select * from diningTable where id = ?", DiningTable.class, id);
}
// 如果餐桌可以预定,接收预定信息,更新餐桌状态,返回 boolean,用于判断是否预定成功
public boolean orderDiningTable(int id, String orderName, String orderTel) {
// 返回影响的行数
int update = diningTableDao.update("update diningTable set state='已经预定', orderName=?, orderTel=? where id=?", orderName, orderTel, id);
return update > 0;
}
// 餐桌预定功能
public void orderDiningTable(){
System.out.println("==============预定餐桌============");
System.out.print("请选择要预定的餐桌编号(-1退出): ");
int orderId = Utility.readInt();
if (orderId == -1) {
System.out.println("==============取消预订餐桌============");
return;
}
//该方法得到的是 Y 或者 N
char key = Utility.readConfirmSelection();
if (key == 'Y') {//要预定
// 判断预定的餐桌是否存在
DiningTable diningTable = getDiningTableById(orderId);
if (diningTable == null) {
System.out.println("==============预订餐桌不存在============");
return;
}
// 判断餐桌的状态是否 "空"
if (!("空".equals(diningTable.getState()))) {//说明当前这个餐桌不是 "空" 状态
System.out.println("==============该餐桌已经预定或者就餐中============");
return;
}
//接收预定信息
System.out.print("预定人的名字: ");
String orderName = Utility.readString(50);
System.out.print("预定人的电话: ");
String orderTel = Utility.readString(50);
//更新餐桌状态
if (orderDiningTable(orderId, orderName, orderTel)) {
System.out.println("==============预订餐桌成功============");
} else {
System.out.println("==============预订餐桌失败============");
}
} else {
System.out.println("==============取消预订餐桌============");
}
}
// 在点餐完成后,需要更新餐桌状态
public boolean updateDiningTableState(int id, String state) {
int update = diningTableDao.update("update diningTable set state=? where id=?", state, id);
return update > 0;
}
}BillService
java
package service;
import dao.BillDao;
import domain.DiningTable;
import domain.Menu;
import utils.Utility;
import java.util.UUID;
/**
* ClassName: BillService
* Package: service
* Description:
*
* @author jacksonling
* @version 1.0
* @Date 2025-08-07 19:56
*/
public class BillService {
private BillDao billDao = new BillDao();
// 调用 MenuService 类中的方法,传入 id,返回菜品对象,用于计算价格
private MenuService menuService = new MenuService();
// 点完餐后需要更新餐桌状态
DiningTableService diningTableService = new DiningTableService();
/**
* 点餐功能
* (1)生成账单
* 参数:订单号、菜品编号、份数、金额、餐桌号、订单日期、订单状态(未结账、已经结账、挂单...)
* 传入参数:菜品编号、份数、餐桌号()
* (2)更新餐桌状态(数据库)
*/
public boolean orderMenu(int menuId, int nums, int diningTableId) {
// 随机生成一个订单号
String billId = UUID.randomUUID().toString();
// 更新账单表,同时根据传入信息计算余额
int update = billDao.update("insert into bill values(null,?,?,?,?,?,now(),'未结账')",
billId, menuId, nums, menuService.getMenuById(menuId).getPrice() * nums, diningTableId);
if (update <= 0) {
return false;
}
//需要更新对应餐桌的状态
return diningTableService.updateDiningTableState(diningTableId, "就餐中");
}
// 用户层点餐界面
public void orderMenu() {
System.out.println("==============点餐服务============");
System.out.print("请输入点餐的桌号(-1退出): ");
int orderDiningTableId = Utility.readInt();
if (orderDiningTableId == -1) {
System.out.println("==============取消点餐============");
return;
}
System.out.print("请输入点餐的菜品号(-1退出): ");
int orderMenuId = Utility.readInt();
if (orderMenuId == -1) {
System.out.println("==============取消点餐============");
return;
}
System.out.print("请输入点餐的菜品量(-1退出): ");
int orderNums = Utility.readInt();
if (orderNums == -1) {
System.out.println("==============取消点餐============");
return;
}
//验证餐桌号是否存在
DiningTable diningTable = diningTableService.getDiningTableById(orderDiningTableId);
if (diningTable == null) {
System.out.println("==============餐桌号不存在============");
return;
}
//验证菜品编号
Menu menu = menuService.getMenuById(orderMenuId);
if (menu == null) {
System.out.println("==============菜品号不存在============");
return;
}
//点餐
if (orderMenu(orderMenuId, orderNums, orderDiningTableId)) {
System.out.println("==============点餐成功============");
} else {
System.out.println("==============点餐失败============");
}
}
}View
java
package view;
import com.sun.org.apache.bcel.internal.generic.NEW;
import domain.Employee;
import service.BillService;
import service.DiningTableService;
import service.EmployeeService;
import service.MenuService;
import utils.Utility;
/**
* ClassName: logInView
* Package: view
* Description:
*
* @author jacksonling
* @version 1.0
* @Date 2025-08-06 14:09
*/
public class View {
// 循环结束标志
boolean loop = true;
// 接收用户输入
String key = "";
// 创建 EmployeeService 对象
EmployeeService employeeService = new EmployeeService();
// 创建 DiningTableService 对象
DiningTableService diningTableService = new DiningTableService();
// 创建 MenuService 对象
MenuService menuService = new MenuService();
// 创建 BillService 对象
BillService billService = new BillService();
//显示主菜单
public void mainMenu() {
while (loop) {
System.out.println("\n===============满汉楼================");
System.out.println("\t\t 1 登录满汉楼");
System.out.println("\t\t 2 退出满汉楼");
System.out.print("请输入你的选择: ");
key = Utility.readString(1);
switch (key) {
case "1":
System.out.print("输入员工号: ");
String empId = Utility.readString(50);
System.out.print("输入密 码: ");
String pwd = Utility.readString(50);
Employee employee = employeeService.getEmployeeByIdAndPwd(empId, pwd);
if (employee != null) { //说明存在该用户
System.out.println("===============登录成功[" + employee.getName() + "]================\n");
//显示二级菜单, 这里二级菜单是循环操作,所以做成while
while (loop) {
System.out.println("\n===============满汉楼(二级菜单)================");
System.out.println("\t\t 1 显示餐桌状态");
System.out.println("\t\t 2 预定餐桌");
System.out.println("\t\t 3 显示所有菜品");
System.out.println("\t\t 4 点餐服务");
System.out.println("\t\t 5 查看账单");
System.out.println("\t\t 6 结账");
System.out.println("\t\t 9 退出满汉楼");
System.out.print("请输入你的选择: ");
key = Utility.readString(1);
switch (key) {
case "1":
// 显示餐桌状态
diningTableService.listDiningTale();
break;
case "2":
// 预定餐桌
diningTableService.orderDiningTable();
break;
case "3":
// 显示所有菜品
menuService.listMenu();
break;
case "4":
// 点餐服务
billService.orderMenu();
break;
case "5":
// 查看账单
System.out.println("查看账单");
break;
case "6":
// 结账
System.out.println("结账");
break;
case "9":
loop = false;
break;
default:
System.out.println("你的输入有误,请重新输入");
break;
}
}
} else {
System.out.println("=====登录失败(用户名 / 密码错误)=====");
}
break;
case "2":
loop = false;//
break;
default:
System.out.println("你输入有误,请重新输入.");
}
}
System.out.println("退出了满汉楼系统~");
}
}