满汉楼小项目
Posted Al_tair
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了满汉楼小项目相关的知识,希望对你有一定的参考价值。
满汉楼(餐馆)
满汉楼(餐馆)
大家好,我是小笙,我完成了韩老师的满汉楼小项目,主要是练习java操作数据库的项目,项目虽然很简陋,但是我觉得可以学到很多基础的东西,不妨大家也来看看!
准备类库
jar包:commins_dbutils-1.3.jar | | druid-1.1.10.jar | | mysql-connector-java-5.1.37-bin.jar
工具类
// JDBCUtilsByDruid.java
public class JDBCUtilsByDruid
private static DataSource dataSource;
static
String filePath = "E:\\\\Java_training\\\\Java_code\\\\JavaIdea03\\\\java" +
"\\\\Javase_HSping\\\\src\\\\com\\\\Al_tair\\\\mhlProject\\\\utils\\\\druid.properties";
Properties properties = new Properties();
try
properties.load(new FileInputStream(filePath));
dataSource = DruidDataSourceFactory.createDataSource(properties);
catch (Exception e)
throw new RuntimeException(e);
// 连接数据库
public static Connection getConnection()
try
// 创建一个指定参数的数据库连接池(德鲁伊连接池)
return dataSource.getConnection();
catch (SQLException throwables)
throw new RuntimeException(throwables);
// 查询语句关闭
public static void closeQueryConnection(Connection connection, Statement statement, ResultSet rst)
try
rst.close();
statement.close();
connection.close();
catch (SQLException throwables)
throw new RuntimeException(throwables);
// dml语句操作关闭
public static void closeDmlConnection(Connection connection,Statement statement)
try
statement.close();
connection.close();
catch (SQLException throwables)
throw new RuntimeException(throwables);
public static void closeConnection(Connection connection)
try
connection.close();
catch (SQLException throwables)
throwables.printStackTrace();
// Utility
// 工具类的作用:
// 处理各种情况的用户输入,并且能够按照程序员的需求,得到用户的控制台输入。
public class Utility
//静态属性。。。
private static Scanner scanner = new Scanner(System.in);
/**
* 功能:读取键盘输入的一个菜单选项,值:1——5的范围
* @return 1——5
*/
public static char readMenuSelection()
char c;
for (; ; )
String str = readKeyBoard(1, false);//包含一个字符的字符串
c = str.charAt(0);//将字符串转换成字符char类型
if (c != '1' && c != '2' &&
c != '3' && c != '4' && c != '5')
System.out.print("选择错误,请重新输入:");
else break;
return c;
/**
* 功能:读取键盘输入的一个字符
* @return 一个字符
*/
public static char readChar()
String str = readKeyBoard(1, false);//就是一个字符
return str.charAt(0);
/**
* 功能:读取键盘输入的一个字符,如果直接按回车,则返回指定的默认值;否则返回输入的那个字符
* @param defaultValue 指定的默认值
* @return 默认值或输入的字符
*/
public static char readChar(char defaultValue)
String str = readKeyBoard(1, true);//要么是空字符串,要么是一个字符
return (str.length() == 0) ? defaultValue : str.charAt(0);
/**
* 功能:读取键盘输入的整型,长度小于2位
* @return 整数
*/
public static int readInt()
int n;
for (; ; )
String str = readKeyBoard(2, false);//一个整数,长度<=2位
try
n = Integer.parseInt(str);//将字符串转换成整数
break;
catch (NumberFormatException e)
System.out.print("数字输入错误,请重新输入:");
return n;
/**
* 功能:读取键盘输入的 整数或默认值,如果直接回车,则返回默认值,否则返回输入的整数
* @param defaultValue 指定的默认值
* @return 整数或默认值
*/
public static int readInt(int defaultValue)
int n;
for (; ; )
String str = readKeyBoard(10, true);
if (str.equals(""))
return defaultValue;
//异常处理...
try
n = Integer.parseInt(str);
break;
catch (NumberFormatException e)
System.out.print("数字输入错误,请重新输入:");
return n;
/**
* 功能:读取键盘输入的指定长度的字符串
* @param limit 限制的长度
* @return 指定长度的字符串
*/
public static String readString(int limit)
return readKeyBoard(limit, false);
/**
* 功能:读取键盘输入的指定长度的字符串或默认值,如果直接回车,返回默认值,否则返回字符串
* @param limit 限制的长度
* @param defaultValue 指定的默认值
* @return 指定长度的字符串
*/
public static String readString(int limit, String defaultValue)
String str = readKeyBoard(limit, true);
return str.equals("")? defaultValue : str;
/**
* 功能:读取键盘输入的确认选项,Y或N
* 将小的功能,封装到一个方法中.
* @return Y或N
*/
public static char readConfirmSelection()
System.out.print("确认是否预订(Y/N): ");
char c;
for (; ; ) //无限循环
//在这里,将接受到字符,转成了大写字母
//y => Y n=>N
String str = readKeyBoard(1, false).toUpperCase();
c = str.charAt(0);
if (c == 'Y' || c == 'N')
break;
else
System.out.print("选择错误,请重新输入:");
return c;
/**
* 功能: 读取一个字符串
* @param limit 读取的长度
* @param blankReturn 如果为true ,表示 可以读空字符串。
* 如果为false表示 不能读空字符串。
*
* 如果输入为空,或者输入大于limit的长度,就会提示重新输入。
* @return
*/
private static String readKeyBoard(int limit, boolean blankReturn)
//定义了字符串
String line = "";
//scanner.hasNextLine() 判断有没有下一行
while (scanner.hasNextLine())
line = scanner.nextLine();//读取这一行
//如果line.length=0, 即用户没有输入任何内容,直接回车
if (line.length() == 0)
if (blankReturn) return line;//如果blankReturn=true,可以返回空串
else continue; //如果blankReturn=false,不接受空串,必须输入内容
//如果用户输入的内容大于了 limit,就提示重写输入
//如果用户如的内容 >0 <= limit ,我就接受
if (line.length() < 1 || line.length() > limit)
System.out.print("输入长度(不能大于" + limit + ")错误,请重新输入:");
continue;
break;
return line;
// druid.properties配置文件(需要自己重新配置)
#key=value
driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3308/al_tair?rewriteBatchedStatements=true&useUnicode=true&characterEncoding=UTF-8
username=root
password=XXXXXXX
#initial connection Size
initialSize=10
#min idle connecton size
minIdle=5
#max active connection size
maxActive=50
#max wait time (5000 mil seconds)
maxWait=5000
主菜单(View层)
package com.Al_tair.mhlProject.view;
import com.Al_tair.mhlProject.domain.Bill;
import com.Al_tair.mhlProject.domain.Employee;
import com.Al_tair.mhlProject.domain.MHLTable;
import com.Al_tair.mhlProject.service.BillService;
import com.Al_tair.mhlProject.service.EmployeeService;
import com.Al_tair.mhlProject.service.MHLTableService;
import com.Al_tair.mhlProject.service.MenuService;
import com.Al_tair.mhlProject.utils.Utility;
import java.util.List;
public class Menu
private boolean loop = true;
private String choice = "";
private EmployeeService employeeService = new EmployeeService();
private MHLTableService mhlTableService = new MHLTableService();
private MenuService menuService = new MenuService();
private BillService billService = new BillService();
/**
* 主菜单
*/
public void MainMenu()
while(loop)
System.out.println("===========满汉楼===========");
System.out.println("\\t\\t 1 登入满汉楼");
System.out.println("\\t\\t 2 退出满汉楼");
System.out.print("请输入你的选择: ");
choice = Utility.readString(1);
switch(choice)
case "1" :
System.out.println("登入到满汉楼");
System.out.print("请输入员工号: ");
String empId = Utility.readString(20);
System.out.print("请输入密码: ");
String pwd = Utility.readString(20);
Employee emp = employeeService.getEmployeeEmpIdAndPwd(empId, pwd);
if(emp != null)
System.out.println("========="+emp.getName()+" 登入成功===========");
SecondMenu();
else
System.out.println("===========登入失败===========");
break;
case "2":
System.out.println("退出满汉楼系统~");
loop = false;
break;
default:
System.out.println("输入错误!");
/**
* 二级菜单
*/
public void SecondMenu()
while(loop)
System.out.println("===========满汉楼(二级菜单)===========");
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 0 退出满汉楼(二级菜单)");
System.out.print("请输入你的选择: ");
choice = Utility.readString(1);
switch (choice)
case "1":
showMHLTable(); // 显示餐桌状态
break;
case "2":
dueToTheTable(); // 预定餐桌
break;
case "3":
showAllMenu(); // 显示所有菜品
break;
case "4":
OrderingService(); // 点餐服务
break;
case "5":
watchBill(); // 查看账单
break;
case "6":
payBill();
break;
case "0":
System.out.println("退出满汉楼(二级菜单)~");
return;
default:
System.out.println("输入错误!");
/**
* 显示餐桌状态
*/
public void showMHLTable()
System.out.println("===========显示餐桌状态===========");
for (MHLTable mhlTable :mhlTableService.tableMessage()
)
System.out.println("\\t\\t桌号: " + mhlTable.getId() + " 餐桌状态: " +mhlTable.getState());
System.out.println();
/**
* 预定餐桌
*/
public void dueToTheTable()
System.out.println("===========预定餐桌===========");
System.out.print("请选择要预定餐桌的编号(-1 退出): ");
int tableId = Utility.readInt();
if(tableId == -1)
System.out.println("退出预定餐桌");
return;
else if(!mhlTableService.IsOrderTable(tableId))
System.out.println("已经被预定或者无该桌号,抱歉");
return以上是关于满汉楼小项目的主要内容,如果未能解决你的问题,请参考以下文章