餐桌、菜系管理

紧接着上次的无线点餐项目,我们今天做餐桌和菜系管理。

1. 餐桌、菜系管理

5.1餐桌、菜系管理流程图解

 

5.2创建数据库、表

项目中采用MySQL数据库存储数据,首先我们需要在MySQL数据库中建立数据库:

/*  删除无线点餐平台数据库,如果存在       */

drop database if exists wirelessplatform;

/*  创建数据,并设置编码     */

create database wirelessplatform default character set utf8;

 

在数据库中我们通过表来存储数据,我们需要建立数据表来存储对应的数据,那么我们的餐桌以及菜系表对应的有哪些字段呢?我们通过餐桌以及菜系的E-R图进行分析:

5.3餐桌及菜系E-R

 

5.4创建餐桌以及菜系表

根据以上餐桌以及菜系的E-R图我们可以创建餐桌以及菜系的数据表,创建表的SQL语句如下:

/*  使用数据库      */

use wirelessplatform;

/*============================*/

/* Table: 餐桌表结构           */

/*============================*/

create table t_board(

/*  餐桌编号,自动增长     */

bid int auto_increment,

/*  餐桌名称     */

bName varchar(30) not null,

/*  是否预定,0表示空闲,1表示预定     */

isBook int(1) default 0,

/*  预定时间    */

bookTime varchar(60) default null,

/*  设置编号为主键    */

primary key(bid)

);

/*============================*/

/* Table: 菜系表结构              */

/*============================*/

create table t_cuisine(

/*  菜系编号,自动增长     */

cid int auto_increment,

/*  菜系名称     */

name varchar(30) not null,

/*  设置编号为主键  */

primary key(cid)

);

5.5MyEclipse中搭建项目开发的包结构

在项目开发中需要分模块开发,每个模块所负责的功能是不同的,这样可以使程序的结构更加清晰,同时也方便于维护。

项目的分包结构如下:

 

 

 

 

5.6创建餐桌和菜系的实体类

疑惑:想想在数据库中使用表来存储数据,那么在程序中使用什么来存储数据呢? 在程序中使用JavaBean对象来存储数据,一个最简单的JavaBean对象只是用来存储数据,作为数据传输的桥梁。下面我们来建立餐桌和菜系的JavaBean

根据数据表分析我们可以建立餐桌与菜系的实体类图:

 

根据餐桌实体类图我们建立对应的实体类:

/**

 * 餐桌实体类

 * @author Leo.Chen

 */

public class Board {

// 餐桌编号

private int bid;

// 餐桌名称

private String bName;

// 是否预定:0表示空闲,1表示预定

private int isBook;

// 预定时间

private String bookTime;

    // 省略set  get...

}

菜系实体类:

/**

 * 菜系实体类

 * @author Leo.Chen

 */

public class Cuisine {

    // 菜系编号

private int cid;

    // 菜系名称

private String name;

    // 省略set  get

}

 

5.7餐桌和菜系的CRUD实现

5.7.1src目录下添加c3p0配置文件c3p0-config.xml

我们的web应用程序需要连接到数据库,把我们网站中的数据保存到数据库中,那么程序与数据库之间怎样才能建立与数据库的连接呢?

我们使用的技术是c3p0连接池技术,使用c3p0连接池来管理数据库连接,当我们需要数据库连接的时候就直接从c3p0连接池中获取即可。

使用c3p0就需要配置c3p0的配置文件:

c3p0-config.xml 配置文件如下:

<?xml version="1.0" encoding="UTF-8"?>

<c3p0-config>

<default-config>

<!-- mysql的数据库连接驱动 -->

<property name="driverClass">com.mysql.jdbc.Driver</property>

<!-- 数据库连接地址 -->

<property name="jdbcUrl">jdbc:mysql://localhost:3306/wirelessplatform</property>

<!-- 用户名 -->

<property name="user">root</property>

<!-- 密码 -->

<property name="password">root</property>

<property name="acquireIncrement">5</property>

<property name="initialPoolSize">10</property>

<property name="minPoolSize">5</property>

<property name="maxPoolSize">20</property>

</default-config>

</c3p0-config>

注意:

1.c3p0的配置文件必须放置在src目录下。

2.配置文件的名字必须是c3p0-config.xml 不能随意取名。

5.7.2创建JDBC工具类获取c3p0连接

    在使用dbutils组件操作数据库的时,对数据进行CRUD操作需要频繁的获取 连接和关闭连接,那么这些获取连接和关闭连接的代码属于重复的代码,我们可以将这些代码抽取到一个工具类中,在工具类中管理数据库连接的获取和关闭工作,同时这些关闭和获取的代码也可以使用c3p0技术来实现,因此最简化的工具类代码可以这样写,代码如下:

JdbcUtil.java类:

import com.mchange.v2.c3p0.ComboPooledDataSource;

/**

 * 数据库连接池工具类

 * @author Leo.Chen

 */

public class JdbcUtil {

// 自定加载src下的c3p0配置文件

private static ComboPooledDataSource dataSource = new ComboPooledDataSource();

 

public static ComboPooledDataSource getDataSource() {

return dataSource;

}

}

5.7.3 餐桌和菜系Dao实现

DaoData Access Object)数据访问对象。负责访问数据库,对数据进行增删改查等处理。数据操作的模型图如下:

BoardDao对象对数据库进行CRUD操作

 

 

l 餐桌Dao实现:

BoardDao接口如下:

public interface BoardDao {

public void save(Board board);

 

public void delete(int id);

 

public void update(Board board);

 

public Board queryAll(int id);

}

 

BoardDaoImpl实现类如下:

public class BoardDaoImpl implements BoardDao {

@Override

public void save(Board board) {

// 建立sql语句

String excuteSql = "insert into t_board(bName,isBook,bookTime) values (?,?,?)";

// 封装参数

Object[] param = { board.getbName(), board.getIsBook(), board.getBookTime() };

try {

// 执行sql语句

runner.update(excuteSql, param);

catch (SQLException e) {

e.printStackTrace();

throw new RuntimeException(e);

}

}

 

@Override

public void delete(int id) {

String excuteSql = "delete from t_board where bid=?";

try {

runner.update(excuteSql, id);

catch (SQLException e) {

e.printStackTrace();

throw new RuntimeException(e);

}

}

 

@Override

public void update(Board board) {

String excuteSql = "update t_board b set b.bname=?, b.isBook=?, b.bookTime=? where b.bid=?";

Object[] param = { board.getbName(), board.getIsBook(), board.getBookTime(), board.getBid()};

try {

runner.update(excuteSql, param);

catch (SQLException e) {

e.printStackTrace();

throw new RuntimeException(e);

}

}

@Override

public List<Board> queryAll() {

String sql = "select * from t_board";

List<Board> resultList = null;

try {

resultList = runner.query(sql, new BeanListHandler<Board>(Board.class));

catch (SQLException e) {

e.printStackTrace();

resultList = new ArrayList<Board>();

}

return resultList;

}

}

 

 

    菜系Dao实现

CuisineDao接口如下:

public interface CuisineDao {

public int save(Cuisine cuisine);

 

public int delete(int id);

 

public int update(Cuisine cuisine);

 

public Cuisine queryAll();

public List<Cuisine> queryByName(String name);

}

CuisineDaoImpl实现类如下:

public class CuisineDaoImpl implements CuisineDao {

@Override

public void save(Cuisine cuisine) {

try {

String sql = "insert into t_cuisine (name) values(?)";

runner.update(sql, cuisine.getName());

catch (SQLException e) {

e.printStackTrace();

throw new RuntimeException(e);

}

}

 

@Override

public void delete(int id) {

try {

String sql = "delete from t_cuisine where cid=?";

runner.update(sql, id);

catch (SQLException e) {

e.printStackTrace();

throw new RuntimeException(e);

}

}

 

@Override

public void update(Cuisine cuisine) {

try {

String sql = "update t_cuisine c set c.name=? where c.cid=?";

runner.update(sql, cuisine.getName(), cuisine.getCid());

catch (SQLException e) {

e.printStackTrace();

throw new RuntimeException(e);

}

}

 

    @Override

public List<Cuisine> queryAll() {

String sql = "select * from t_cuisine";

List<Cuisine> resultList = null;

try {

resultList = runner.query(sql, new BeanListHandler<Cuisine>(Cuisine.class));

catch (SQLException e) {

e.printStackTrace();

resultList = new ArrayList<Cuisine>();

}

return resultList;

}

 

@Override

public List<Cuisine> queryByName(String name) {

List<Cuisine> resultList = null;

try {

String sql = "select * from t_cuisine where name like '%"+name+"%'";

resultList = runner.query(sql, new BeanListHandler<Cuisine>(Cuisine.class));

catch (SQLException e) {

e.printStackTrace();

resultList = new ArrayList<Cuisine>();

}

return resultList;

}

}


  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
客户管理 1) 功能描述:增加客户(其中有个重要的信息是否为会员一般默认为否) 输入:客户信息姓名、性别、联系电话、客户类型(企事业单位,个人),描述 处理: 客户进入餐厅时,进入新增客户界面 输入客户信息,包含姓名、性别、联系电话、客户类型(企事业单位,个人),描述; 点击“新增”按钮,增加客户信息,系统自动生成客户编号,然后显示所有客户信息; 客户编号生成的规则为:注册客户的年、月、日+客户序号(00000)。 输出:增加的所有客户信息 异常信息:出现异常新增中出现了重复客户信息 处理异常:将阻止用户添加该用户添加,并弹出提示框,提醒用户该用户已经添加过了 2) 功能描述:修改客户信息 输入:需要修改的客户编号或客户姓名 处理: 输入客户编号或客户姓名,查询出客户的信息; 在查询结果中,选择需要修改的客户并修改其信息; 确认修改信息后点击“修改”按钮,提交修改。 输出:修改后的客户的信息 异常信息:所修改的信息不符合规则,如电话号码位数不对等 处理异常:将阻止用户对数据的修改,弹出对话框进行提示 3) 功能描述:删除客户信息 输入:需要删除的客户编号或客户姓名 处理: 输入客户编号或客户姓名,查询出客户的信息; 在查询结果中,选择需要删除的客户并修改其信息; 确认删除信息后点击“删除”按钮,提交删除。 输出:所有未删除的客户的信息 异常信息:为选中需要删除的客户 异常处理:阻止删除操作,弹出对话框提醒用户未选中删除项 4) 功能描述:查询客户信息 输入:客户编号、客户姓名或者手机号 处理: 输入客户编号、客户姓名或者手机号; 点击“查询”按钮。 输出:满足查询条件的客户信息 异常信息:输入的条件没有满足客户信息 处理异常:阻止查询,弹出对话框提示用户输入条件有错 5) 功能描述:开通VIP 输入:VIP信息或是客户编号或客户姓名 处理: 新客户开通VIP 客户进入餐厅时,进入新增客户界面; 输入客户信息,包含姓名、性别、联系电话、客户类型(企事业单位,个人),描述,为会员; 点击“新增”按钮,增加客户信息,系统自动生成客户编号,然后显示所有客户信息; 客户编号生成的规则为:注册客户的年、月、日+客户序号(00000)。 老客户开通会员 输入客户编号、客户姓名或者手机号; 点击“查询”按钮; 在查询结果中,选择要开通会员的客户,将其是否为会员的信息修改为“是“; 确认信息后点击“修改”按钮,提交修改。 输出:所有VIP会员的信息 异常信息: 异常处理: 预订管理 1) 功能描述:预订 输入:预订者联系电话,预订人姓名,预订开餐日期和时间,到餐人数 处理: 当预订客户打来电话或其他方式预订,进入预订界面; 输入预订者联系电话,预订人姓名,预订开餐日期和时间,到餐人数; 核对预订信息后,点击“预订”按钮,提交预订信息。 输出:所以预订信息 异常信息:没有符合客户要求的预订 异常处理:阻止预订操作的进行,并弹出提示框“无符合预订的条件” 2)    2.1 功能描述:修改预订 2.2 输入:预订者联系电话,预订人姓名 2.3 处理:      2.3.1 预订客户提供其联系方式,或者姓名,查询出预订信息      2.3.2 修改其到餐时间,预订菜单,预订包间、餐桌等信息      2.3.2 点击“修改”按钮, 2.4 输出:修改后的预订信息 2.5 异常信息:没有符合客户要求的预订 2.6 异常处理:阻止预订操作的进行,并弹出提示框“无符合预订的条件” 3)    2.1 功能描述:取消预订 2.2 输入:预订者联系电话,预订人姓名 2.3 处理:      2.3.1预订客户提供其联系方式,或者姓名,查询出预订信息;      2.3.2 选中需要删除的预订信息;      2.3.2 核对要删除预订信息后,点击“删除”按钮 2.4 输出:所以预订信息 2.5 异常信息:没有选中需要删除的预订信息 2.6 异常处理:阻止删除预订操作的进行,并弹出提示框“请选中需删除的预订信息” 4)    2.1 功能描述:查询预订 2.2 输入:预订者联系电话,预订人姓名 2.3 处理:      2.3.1预订客户提供其联系方式,或者姓名,查询出预订信息;      2.3.2点击“查询”按钮。 2.4 输出:符合条件的预订信息 2.5 异常信息:输入的条件没有满足客户信息 2.6 异常处理:阻止查询,弹出对话框提示用户输入条件有错 桌台管理    1) 功能描述:开台 输入:餐桌号 处理: 查看餐桌开台状态; 将该餐桌状态修改为开台。 输出:餐桌
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Seven的代码实验室

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值