餐厅点餐系统

2024-08-22 19:28
文章标签 系统 点餐 餐厅

本文主要是介绍餐厅点餐系统,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

@TOC

springboot0742餐厅点餐系统

系统概述

进过系统的分析后,就开始记性系统的设计,系统设计包含总体设计和详细设计。总体设计只是一个大体的设计,经过了总体设计,我们能够划分出系统的一些东西,例如文件、文档、数据等。而且我们通过总体设计,大致可以划分出了程序的模块,以及功能。但是只是一个初步的分类,并没有真正的实现。

整体设计,只是一个初步设计,而且,对于一个项目,我们可以进行多个整体设计,通过对比,包括性能的对比、成本的对比、效益的对比,来最终确定一个最优的设计方案,选择优秀的整体设计可以降低开发成本,增加公司效益,从这一点来讲,整体设计还是非常重要的。

高校校园点餐系统工作原理图如图4-1所示:

图4-1 系统工作原理图

4.2 系统结构设计

系统架构图属于系统设计阶段,系统架构图只是这个阶段一个产物,系统的总体架构决定了整个系统的模式,是系统的基础。高校校园点餐系统的整体结构设计如图4-2所示。

图4-2 系统结构图

4.3数据库设计

数据库是计算机信息系统的基础。目前,电脑系统的关键与核心部分就是数据库。数据库开发的优劣对整个系统的质量和速度有着直接影响。

4.3.1 数据库设计原则

数据库的概念结构设计采用实体—联系(E-R)模型设计方法。E-R模型法的组成元素有:实体、属性、联系,E-R模型用E-R图表示,是提示用户工作环境中所涉及的事物,属性则是对实体特性的描述。在系统设计当中数据库起着决定性的因素。下面设计出这几个关键实体的实体—关系图。

4.3.2 数据库实体

数据模型中的实体(Entity),也称为实例,对应现实世界中可区别于其他对象的“事件”或“事物”。例如,学校中的每个学生,家里中的每个家具。

本系统的E-R图如下图所示:

1、用户信息实体图如图4-3所示:

图4-3用户信息实体图

2、食堂信息实体图如图4-4所示:

图4-4食堂信息实体图

3、留言板信息实体图如图4-5所示:

图4-5留言板信息实体图

#########

4.3.3 数据库表设计

数据库的表信息属于设计的一部分,下面介绍数据库中的各个表的详细信息。

表名:shitang

功能:食堂表

字段名称类型长度字段说明主键默认值
idbigint主键主键
addtimetimestamp新增时间CURRENT_TIMESTAMP
shitanghaovarchar100食堂号
mimavarchar100密码
shitangmingvarchar100食堂名
guanliyuanvarchar200管理员
shitangzhaopianvarchar100食堂照片
weishengdengjivarchar200卫生等级
lianxidianhuavarchar200联系电话
shitangdizhivarchar200食堂地址

表名:shitangcaidan

功能:食堂菜单表

字段名称类型长度字段说明主键默认值
idbigint主键主键
addtimetimestamp创建时间CURRENT_TIMESTAMP
shitanghaovarchar200食堂号
shitangmingvarchar200食堂名
caipinvarchar200菜品
caixivarchar200菜系
tupianvarchar200图片
fenliangvarchar200分量
shicaivarchar200食材
shitangdizhivarchar200食堂订单
xiangqingvarchar200详情

表名:xiaoxiliuyan

功能:消息留言表

字段名称类型长度字段说明主键默认值
idbigint主键主键
addtimetimestamp创建时间CURRENT_TIMESTAMP
zhanghaovarchar200账号
xingmingvarchar200姓名
jiaoselongtext4294967295角色
shitanghaovarchar200食堂号
shitangmingvarchar200食堂名
dingdanhaovarchar200订单号
peisongfenvarchar200配送分
baozhuangfenvarchar200包装分
caipinfenvarchar200菜品分
shijianvarchar200时间
jianyivarchar200建议
sfshvarchar200是否审核
shhfvarchar200审核回复

表名:caixifenlei

功能:菜系分类表

字段名称类型长度字段说明主键默认值
idbigint主键主键
addtimetimestamp创建时间CURRENT_TIMESTAMP
caixivarchar200菜系

表名:yonghu

功能:用户表

字段名称类型长度字段说明主键默认值
idbigint主键主键
addtimetimestamp新增时间CURRENT_TIMESTAMP
zhanghaovarchar100账号
mimavarchar100密码
xingmingvarchar100姓名
jiaosevarchar100角色
xingbievarchar100性别
nianlingvarchar100年龄
shoujivarchar100手机
youxiangvarchar100邮箱
zhaopianvarchar100照片

5统详细设计

5.1前台首页功能模块

高校校园点餐系统,在系统首页可以查看首页、食堂菜单、新闻资讯、留言反馈、我的、跳转到后台、购物车等内容,如图5-1所示。

图5-1前台首页功能界面图

用户注册、用户登录,在用户注册页面可以填写账号、密码、姓名、角色、性别、年龄、手机、邮箱等信息进行用户注册、登录,如图5-2所示。

图5-2用户注册、登录界面图 ######### 食堂菜单,在食堂菜单页面通过填写食堂号、食堂名、菜品、菜系、图片、分量、食材、食堂地址、详情、价格、座位总数等信息进行添加到购物车、立即预定、点我收藏等操作,如图5-3所示。在我的地址页面通过填写联系人、手机号码、默认地址、选择地址等信息进行添加或重置操作,如图5-4所示。

图5-3食堂菜单界面图 #########

图5-4我的地址界面图

5.2管理员功能模块

管理员登录,通过填写输入用户名、密码进行登录,如图5-5所示。

图5-5管理员登录界面图

管理员登录进入高校校园点餐系统可以查看个人中心、用户管理、食堂管理、食堂菜单管理、菜系分类管理、消息留言管理、留言板管理、系统管理、订单管理等信息。

用户管理,在用户管理页面中可以通过填写账号、密码、姓名、角色、性别、年龄、手机、邮箱、照片、余额等内容进行查看、修改、删除等操作,如图5-6所示。

食堂管理,在食堂管理页面中可以查看食食堂号、密码、食堂名、管理员、食堂照片、卫生等级、联系电话、食堂地址、余额等信息,并可根据需要对已有食堂管理进行查看、修改、删除等操作,如图5-7所示。

图5-6用户管理界面图

图5-7食堂管理界面图

菜系分类管理,在菜系分类管理页面中可以查看菜系等信息,并可根据需要对已有菜系分类管理进行修改或删除等操作,如图5-8所示。

图5-8菜系分类管理界面图

消息留言管理,在消息留言管理页面中可以查看账号、姓名、角色、食堂号、食堂名、订单号、配送分、包装分、菜品分、时间、建议、是否审核、审核回复等信息,并可根据需要对已有消息留言管理进行审核、查看、修改或删除等详细操作,如图5-9所示。

图5-9消息留言管理界面图

留言板管理,在留言板管理页面中可以查看留言人id 、用户名、留言内容、回复内容等内容,并且根据需要对已有留言板管理进行查看、回复、修改或删除等详细操作,如图5-10所示。

图5-10留言板管理界面图

美食资讯管理,在美食资讯管理页面中可以查看标题、简介、图片、内容等内容,并且根据需要对已有美食资讯管理进行查看、修改或删除等详细操作,如图5-11所示。

图5-11美食资讯管理界面图

订单管理,在订单管理页面中可以查看订单编号、商品表名、用户ID、商品ID、商品名称、商品图片、购买数量、价格/积分、折扣价格、总价格/总积分、折扣总价格、

支付类型、状态、地址等内容,并且根据需要对已有订单管理进行查看,修改或删除等详细操作,如图5-12所示。

图5-12订单管理界面图

5.3食堂功能模块

食堂登录进入高校校园点餐系统可以查看个人中心、食堂菜单管理、菜系分类管理、消息留言管理、订单管理等内容。

食堂菜单管理,在食堂菜单管理页面中通过填写食堂号、食堂名、菜品、菜系、图片、分量、食材、食堂地址、详情、价格、座位总数、已选座位[用号隔开]等信息,还可以根据需要对食堂菜单管理进行查看、修改、删除等操作,如图5-13所示。

图5-13食堂菜单管理界面图

菜系分类管理,在菜系分类管理页面中可以填写菜系等信息,并且根据需要对已有菜系分类管理进行修改、删除等其他详细操作,如图5-14所示。

图5-14菜系分类管理界面图 ######### 订单管理,在订单管理页面中通过填写订单编号、商品表名、用户ID、商品ID、商品名称、商品图片、购买数量、价格/积分、折扣价格、总价格/总积分、折扣总价格、

支付类型、状态、地址等内容进行查看、发货等操作,如图5-15所示。

图5-15订单管理界面图 #########

5.4用户功能模块

用户登录进入高校校园点餐系统可以查看个人中心、消息留言管理、我的收藏管理、订单管理等内容。

消息留言管理,在消息留言管理页面中通过填写账号、姓名、角色、食堂号、食堂名、订单号、配送分、包装分、菜品分、时间、建议、是否审核、审核回复等信息,还可以根据需要对消息留言管理进行查看、修改、删除等操作,如图5-16所示。

图5-16消息留言管理界面图

订单管理,在订单管理页面中可以查看订单编号、商品表名、用户ID、商品ID、商品名称、商品图片、购买数量、价格/积分、折扣价格、总价格/总积分、折扣总价格、

支付类型、状态、地址等信息,并且根据需要对已有订单管理进行查看等其他详细操作,如图5-17所示。

图5-17订单管理界面图 #########

#########

NewsServiceImpl.java
package com.service.impl;import org.springframework.stereotype.Service;
import java.util.Map;
import java.util.List;import com.baomidou.mybatisplus.mapper.Wrapper;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.baomidou.mybatisplus.plugins.Page;
import com.baomidou.mybatisplus.service.impl.ServiceImpl;
import com.utils.PageUtils;
import com.utils.Query;import com.dao.NewsDao;
import com.entity.NewsEntity;
import com.service.NewsService;
import com.entity.vo.NewsVO;
import com.entity.view.NewsView;@Service("newsService")
public class NewsServiceImpl extends ServiceImpl<NewsDao, NewsEntity> implements NewsService {@Overridepublic PageUtils queryPage(Map<String, Object> params) {Page<NewsEntity> page = this.selectPage(new Query<NewsEntity>(params).getPage(),new EntityWrapper<NewsEntity>());return new PageUtils(page);}@Overridepublic PageUtils queryPage(Map<String, Object> params, Wrapper<NewsEntity> wrapper) {Page<NewsView> page =new Query<NewsView>(params).getPage();page.setRecords(baseMapper.selectListView(page,wrapper));PageUtils pageUtil = new PageUtils(page);return pageUtil;}@Overridepublic List<NewsVO> selectListVO(Wrapper<NewsEntity> wrapper) {return baseMapper.selectListVO(wrapper);}@Overridepublic NewsVO selectVO(Wrapper<NewsEntity> wrapper) {return baseMapper.selectVO(wrapper);}@Overridepublic List<NewsView> selectListView(Wrapper<NewsEntity> wrapper) {return baseMapper.selectListView(wrapper);}@Overridepublic NewsView selectView(Wrapper<NewsEntity> wrapper) {return baseMapper.selectView(wrapper);}}
CaipindingdanController.java
package com.controller;import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Calendar;
import java.util.Map;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Date;
import java.util.List;
import javax.servlet.http.HttpServletRequest;import com.utils.ValidatorUtils;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.format.annotation.DateTimeFormat;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.baomidou.mybatisplus.mapper.Wrapper;
import com.annotation.IgnoreAuth;import com.entity.CaipindingdanEntity;
import com.entity.view.CaipindingdanView;import com.service.CaipindingdanService;
import com.service.TokenService;
import com.utils.PageUtils;
import com.utils.R;
import com.utils.MD5Util;
import com.utils.MPUtil;
import com.utils.CommonUtil;/*** 菜品订单* 后端接口* @author * @email * @date 2021-03-20 21:35:40*/
@RestController
@RequestMapping("/caipindingdan")
public class CaipindingdanController {@Autowiredprivate CaipindingdanService caipindingdanService;/*** 后端列表*/@RequestMapping("/page")public R page(@RequestParam Map<String, Object> params,CaipindingdanEntity caipindingdan,HttpServletRequest request){String tableName = request.getSession().getAttribute("tableName").toString();if(tableName.equals("yonghu")) {caipindingdan.setYonghuming((String)request.getSession().getAttribute("username"));}EntityWrapper<CaipindingdanEntity> ew = new EntityWrapper<CaipindingdanEntity>();PageUtils page = caipindingdanService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, caipindingdan), params), params));return R.ok().put("data", page);}/*** 前端列表*/@RequestMapping("/list")public R list(@RequestParam Map<String, Object> params,CaipindingdanEntity caipindingdan, HttpServletRequest request){EntityWrapper<CaipindingdanEntity> ew = new EntityWrapper<CaipindingdanEntity>();PageUtils page = caipindingdanService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, caipindingdan), params), params));return R.ok().put("data", page);}/*** 列表*/@RequestMapping("/lists")public R list( CaipindingdanEntity caipindingdan){EntityWrapper<CaipindingdanEntity> ew = new EntityWrapper<CaipindingdanEntity>();ew.allEq(MPUtil.allEQMapPre( caipindingdan, "caipindingdan")); return R.ok().put("data", caipindingdanService.selectListView(ew));}/*** 查询*/@RequestMapping("/query")public R query(CaipindingdanEntity caipindingdan){EntityWrapper< CaipindingdanEntity> ew = new EntityWrapper< CaipindingdanEntity>();ew.allEq(MPUtil.allEQMapPre( caipindingdan, "caipindingdan")); CaipindingdanView caipindingdanView =  caipindingdanService.selectView(ew);return R.ok("查询菜品订单成功").put("data", caipindingdanView);}/*** 后端详情*/@RequestMapping("/info/{id}")public R info(@PathVariable("id") Long id){CaipindingdanEntity caipindingdan = caipindingdanService.selectById(id);return R.ok().put("data", caipindingdan);}/*** 前端详情*/@RequestMapping("/detail/{id}")public R detail(@PathVariable("id") Long id){CaipindingdanEntity caipindingdan = caipindingdanService.selectById(id);return R.ok().put("data", caipindingdan);}/*** 后端保存*/@RequestMapping("/save")public R save(@RequestBody CaipindingdanEntity caipindingdan, HttpServletRequest request){caipindingdan.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());//ValidatorUtils.validateEntity(caipindingdan);caipindingdanService.insert(caipindingdan);return R.ok();}/*** 前端保存*/@RequestMapping("/add")public R add(@RequestBody CaipindingdanEntity caipindingdan, HttpServletRequest request){caipindingdan.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());//ValidatorUtils.validateEntity(caipindingdan);caipindingdanService.insert(caipindingdan);return R.ok();}/*** 修改*/@RequestMapping("/update")public R update(@RequestBody CaipindingdanEntity caipindingdan, HttpServletRequest request){//ValidatorUtils.validateEntity(caipindingdan);caipindingdanService.updateById(caipindingdan);//全部更新return R.ok();}/*** 删除*/@RequestMapping("/delete")public R delete(@RequestBody Long[] ids){caipindingdanService.deleteBatchIds(Arrays.asList(ids));return R.ok();}/*** 提醒接口*/@RequestMapping("/remind/{columnName}/{type}")public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request, @PathVariable("type") String type,@RequestParam Map<String, Object> map) {map.put("column", columnName);map.put("type", type);if(type.equals("2")) {SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");Calendar c = Calendar.getInstance();Date remindStartDate = null;Date remindEndDate = null;if(map.get("remindstart")!=null) {Integer remindStart = Integer.parseInt(map.get("remindstart").toString());c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindStart);remindStartDate = c.getTime();map.put("remindstart", sdf.format(remindStartDate));}if(map.get("remindend")!=null) {Integer remindEnd = Integer.parseInt(map.get("remindend").toString());c.setTime(new Date());c.add(Calendar.DAY_OF_MONTH,remindEnd);remindEndDate = c.getTime();map.put("remindend", sdf.format(remindEndDate));}}Wrapper<CaipindingdanEntity> wrapper = new EntityWrapper<CaipindingdanEntity>();if(map.get("remindstart")!=null) {wrapper.ge(columnName, map.get("remindstart"));}if(map.get("remindend")!=null) {wrapper.le(columnName, map.get("remindend"));}String tableName = request.getSession().getAttribute("tableName").toString();if(tableName.equals("yonghu")) {wrapper.eq("yonghuming", (String)request.getSession().getAttribute("username"));}int count = caipindingdanService.selectCount(wrapper);return R.ok().put("count", count);}}
ConfigServiceImpl.java

package com.service.impl;import java.util.Map;import org.springframework.stereotype.Service;import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.baomidou.mybatisplus.plugins.Page;
import com.baomidou.mybatisplus.service.impl.ServiceImpl;
import com.dao.ConfigDao;
import com.entity.ConfigEntity;
import com.entity.UserEntity;
import com.service.ConfigService;
import com.utils.PageUtils;
import com.utils.Query;/*** 系统用户*/
@Service("configService")
public class ConfigServiceImpl extends ServiceImpl<ConfigDao, ConfigEntity> implements ConfigService {@Overridepublic PageUtils queryPage(Map<String, Object> params) {Page<ConfigEntity> page = this.selectPage(new Query<ConfigEntity>(params).getPage(),new EntityWrapper<ConfigEntity>());return new PageUtils(page);}
}
store.js

这篇关于餐厅点餐系统的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1097179

相关文章

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

基于人工智能的图像分类系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 图像分类是计算机视觉中的一个重要任务,目标是自动识别图像中的对象类别。通过卷积神经网络(CNN)等深度学习技术,我们可以构建高效的图像分类系统,广泛应用于自动驾驶、医疗影像诊断、监控分析等领域。本文将介绍如何构建一个基于人工智能的图像分类系统,包括环境

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、

软考系统规划与管理师考试证书含金量高吗?

2024年软考系统规划与管理师考试报名时间节点: 报名时间:2024年上半年软考将于3月中旬陆续开始报名 考试时间:上半年5月25日到28日,下半年11月9日到12日 分数线:所有科目成绩均须达到45分以上(包括45分)方可通过考试 成绩查询:可在“中国计算机技术职业资格网”上查询软考成绩 出成绩时间:预计在11月左右 证书领取时间:一般在考试成绩公布后3~4个月,各地领取时间有所不同

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

基于 YOLOv5 的积水检测系统:打造高效智能的智慧城市应用

在城市发展中,积水问题日益严重,特别是在大雨过后,积水往往会影响交通甚至威胁人们的安全。通过现代计算机视觉技术,我们能够智能化地检测和识别积水区域,减少潜在危险。本文将介绍如何使用 YOLOv5 和 PyQt5 搭建一个积水检测系统,结合深度学习和直观的图形界面,为用户提供高效的解决方案。 源码地址: PyQt5+YoloV5 实现积水检测系统 预览: 项目背景