基于python Django 餐馆点菜管理系统

news2025/1/18 20:16:09

问题描述: 随着网络的迅速发展,越来越多的人开始接受甚至时依赖了网络营业的这种交易形式,传统的点菜模式不仅浪费时间,效率低下,而且特别耗费成本与人力,因此不少商家开始使用网上点菜系统。网上点菜系统是一种可以自主选择、个性化、便捷化、特色化的点餐模式,它的大力推广使用为餐厅节约了成本,同时也解决了消费者在传统点菜时存在的不少麻烦,这使得网上点菜系统迅速占领市场。

2、设计要求

该系统设计实现时主要从以下三个角色方面入手进行,每个角色具有不同功能:

  1. 用户端功能:

  • 顾客进入系统浏览整体菜单;

  • 顾客根据菜单进行选菜下单点菜;

  • 顾客通过核对订单进行结账。

  1. 后台管理功能:

  • 管理员可以进入后台系统;

  • 管理员可以查询系统内所有存在订单;

  • 管理员有权对所有在职员工信息进行操作。

  1. 后厨系统功能:

  • 订单保存在数据库中,并传入后厨系统;

  • 后厨界面同步显示所有正在进行的订单;

  • 后厨对订单具有查询,接单等操作功能。

三.课程设计说明书


1 需求分析

(1) 数据需求

点菜管理信息系统需要完成功能主要有:

  1. 餐厅基础信息:餐厅提供基本的菜谱等信息并且能对所有信息进行增、删、改、查等操作;

  1. 顾客点菜信息:用户登录系统后,在相应的页面浏览菜谱信息,根据自己的用餐需求下单,使得该信息显示在系统订单信息列表中,在结账时通过订单信息进行结账;

  1. 职工管理信息:管理员可以登录该系统对已经注册的职工个人信息进行增、删、改、查等操作;

(2) 事务需求

  1. 在餐厅基础信息部分,要求:

  • 展示整体菜谱,主要由菜品编号、菜名、数量、价格等组成;

  • 菜谱上所有信息管理员都有权进行更新修改。

  1. 在顾客点菜信息部分,要求:

  • 通过自主选择桌号进入点菜;

  • 浏览所有的菜谱信息;

  • 通过自主选择菜品,生成订单;

  • 核对订单信息及订单状态,完成结账。

  1. 在职工管理信息部分,要求:

  • 在职员工通过身份信息注册、登陆系统;

  • 职工有权对自己的职工信息进行增、删、改等操作;

  • 管理员可以对所有职工信息进行查询及操作。

(3) 关系模式

  1. 菜品类(菜品编号,菜品名称)

  1. 菜品(菜品编号,菜品种类编号,菜名,制作时间,数量,价格)

  1. 订单(订单编号,餐桌编号,菜品总数,消费金额,下单时间,备注信息,支付时间,负责职工编号,支付状态)

  1. 订单明细(编号,订单编号,菜品编号,菜品数量,消费金额,备注信息,订单状态,接单时间,完成时间)

  1. 职工(职工编号,个人 ID,姓名,性别,出生日期,联系方式,联系地址)

  1. 餐桌信息(餐桌编号,餐桌名字,负责职工编号)

(4) 数据字典

  1. 菜品类表

字段

类型

可否为 Null

主外码

默认值

中文名

ID

Int

NotNull

主码

菜品类编号

name

Varchar(20)

NotNull

菜品类名称

  1. 菜品表

字段

类型

可否为 Null

主外码

默认值

中文名

ID

Int

NotNull

主码

菜品编号

foodType_id

Int

外码

菜品种类编号

title

Varchar(20)

NotNull

菜名

cost_time

Int

制作时间

amount

Int

NotNull

大于 0

数量

price

Float

NotNull

大于 0

价格

  1. 订单表

字段

类型

可否为 Null

主外码

默认值

中文名

ID

Int

主码

订单编号

table_id

Int

餐桌编号

food_amount

Int

菜品总数

table_price

Float

消费金额

create_time

Varchar(20)

下单时间

pay_time

Varchar(20)

支付时间

staff_id

Int

外码

负责职工编号

is-pay

Boolean

支付状态

comment

Varchar(50)

备注

  1. 订单明细表

字段

类型

可否为 Null

主外键

默认值

中文名

id

Int

主码

编号

orderID_id

Int

NotNull

外码

订单编号

foodID_id

Int

NotNull

外码

菜品编号

amount

Int

NotNull

大于 0

菜品数量

sum_price

Float

消费金额

comment

Varchar(50)

备注信息

status

Varchar(20)

NotNull

订单状态

start_cook_time

接单时间

end_cook_time

完成时间

  1. 职工表

字段

类型

可否为 Null

主外键

默认值

中文名

ID

Int

NotNull

主码

职工编号

citizenID

Varchar(20)

NotNull

个人 ID

name

Varchar(20)

NotNull

姓名

gender

Varchar(20)

NotNull

性别

born_date

Varchar(20)

出生日期

phone

Varchar(20)

NotNull

联系方式

address

Varchar(50)

联系地址

  1. 餐桌信息表

字段

类型

可否为 Null

主外键

默认值

中文名

ID

主码

餐桌编号

name

餐桌名字

staff_id

外码

负责职工编号

2 概要设计

(1) 实体图及 E-R 图

(2) 数据流图

3 逻辑设计

4 数据库建立

(1) 创建数据库

Django 中默认使用 SQLite 作为数据库,也可将其换为 MySQL、Oracle 等,仅需提供连接地址、用户名及密码。

(2) 菜品类表建立

CREATE TABLE OrderSystem_foodtype
(
  ID  INTEGER   NOT NULL  PRIMARY KEY AUTOINCREMENT,
  name VARCHAR (20) NOT NULL
);

(3) 菜品表建立

CREATE TABLE OrderSystem_food
(
    title       VARCHAR (20) NOT NULL,
    amount      INTEGER      NOT NULL,
    price       REAL         NOT NULL,
    ID          INTEGER      NOT NULL  PRIMARY KEY AUTOINCREMENT,
	foodType_id INTEGER      NOT NULL  REFERENCES 
		OrderSystem_foodtype (ID)  DEFERRABLE INITIALLY DEFERRED,
    cost_time   INTEGER      NOT NULL
);

(4) 订单表建立

CREATE TABLE OrderSystem_order(
    ID          INTEGER  NOT NULL  PRIMARY KEY AUTOINCREMENT,
    table_id    INTEGER  NOT NULL,
    food_amount INTEGER  NOT NULL,
    total_price REAL     NOT NULL,
    staff_id    INTEGER  NOT NULL  REFERENCES
		OrderSystem_staff (ID) DEFERRABLE INITIALLY DEFERRED,
    is_pay      BOOL     NOT NULL,
    create_time DATETIME NOT NULL,
	pay_time    DATETIME,
	comment     VARCHAR (50) NOT NULL
);

(5) 订单明细表建立

CREATE TABLE OrderSystem_orderitem 
(
    id              INTEGER      NOT NULL  PRIMARY KEY AUTOINCREMENT,
    amount          INTEGER      NOT NULL,
    sum_price       REAL         NOT NULL,
    orderID_id      INTEGER      NOT NULL  REFERENCES
		OrderSystem_order (ID) DEFERRABLE INITIALLY DEFERRED,
    end_cook_time   TIME,
    start_cook_time TIME,
    status          INTEGER      NOT NULL,
    comment         VARCHAR (50) NOT NULL,
	foodID_id       INTEGER      REFERENCES 
	OrderSystem_food (ID) DEFERRABLE INITIALLY DEFERRED
);

(6) 职工信息表建立

CREATE TABLE OrderSystem_staff 
(
    ID        INTEGER      NOT NULL  PRIMARY KEY AUTOINCREMENT,
    citizenID VARCHAR (20) NOT NULL,
    name      VARCHAR (10) NOT NULL,
    gender    VARCHAR (5)  NOT NULL,
    born_date DATE,
    phone     VARCHAR (11) NOT NULL,
    address   VARCHAR (50) NOT NULL
);

(7) 餐桌信息表建立

CREATE TABLE OrderSystem_staff_table 
(
  ID    INTEGER   NOT NULL PRIMARY KEY,
  name   VARCHAR (20) NOT NULL,
  staff_id INTEGER   NOT NULL  REFERENCES
  	OrderSystem_staff (ID) DEFERRABLE INITIALLY DEFERRED
);

5 系统实现

(1)系统功能模块图

(2)前台开发平台的选择

  • Web 前端使用 jQuery、Bootstrap4 等进行实现;

  • 使用 Python + Django 作为后端实现;

  • 使用 SQLite 进行数据库实现。

(3)设计与实现

  1. 展示所有菜品类及菜品,顾客可以自主选择餐桌及菜品来进行下单

  1. 生成订单明细,顾客可以对自己的订单进行查询核对

  1. 管理员及职工注册,然后通过登陆进入后台管理系统

  1. 后台管理系统同步显示订单及当前订单所有状态,后厨完成订单时选择上菜,管理界面自动刷新提示服务员进行上菜服务,餐桌负责人后台可自行切换

  1. 点击结账时可以先核对订单,然后再进行对订单的批量支付或者全部支付

  1. 后台管理系统显示所有订单以及订单支付状态,红色为未支付订单,绿色为已支付订单,点击订单号可进入对应订单的详情页

  1. 管理员对菜品类、菜品、餐桌信息、员工信息等进行更新操作,即增、删、改等

  1. 进如后厨系统,后厨对订单信息进行选择接单,完成后通知上菜等操作,订单明细显示 4 种状态(等待后厨接单,后厨已接单,等待上菜,上菜完成)

6 编程与调试总结

在前端遇到的最多的问题就是对齐,在 JavaScript 以及 jQuery 的操作中,经常会发生无法绑定的情况,后来知道是因为我们的页面是动态加载,一次绑定无法将新的 HTML 元素也进行绑定,最后统一将绑定的操作放在了动态加载之后,而管理和后厨页面中的一些元素需要隔 10 秒、30 秒刷新餐桌信息和上菜信息的就需要在刷新的函数后面再进行绑定。

用 Django 写后端还是比较容易的,但是因为不是很熟悉这个框架,所以在 url 的路由设置上没有很清晰的分界,将管理与顾客点菜子系统放在了同一个 app 中,虽然便于处理数据,但是导致一个 app 的内容很多,不便于调试时查找,使得代码可读性变低,但好在 Django 框架将后端分为了页面视图 views、页面模板 templates 和数据关系模型 models 等,代码的耦合度不至于很高。

在做管理页面时遇到了数据库关系表中的外键在被参照表中数据被删除时参照表需不需要级联删除的问题,因为一开始将其设计成了 SET_NULL,但是实际调试时发现数据库报错,将 SQL 语句放在数据库中执行发现无法将其设为 NULL,最后查阅了相关问题的资料后将其设计成可以为空。

7 课程设计心得体会

这次的数据库课程设计只有一个星期的时间,而我们需要将在数据库课堂上和实验中学习到的知识运用到实际的管理系统中,还需要设计相应的界面,这着实不是一件容易的事情。

确定选择“点菜管理系统”这个题目后,我们通过查找相关资料以及自己对点菜系统的理解确定了需要做的几个主要功能:点菜、结账、查账等,然后一点一点拓展到现在的所有功能。功能的完善大多是在开发过程中因为实际需要而发现问题并解决的,还有的是为了更人性化更适合用户角度使用而添加的,相应的数据库表单也是在开发过程中逐步完善。

但是这样的开发是有问题的,比如订单的几个数据项前前后后改了很多次,因为生成订单需要前后端沟通,每次修改也就会耗费许多时间来进行调试,而如果一开始就能详细地对订单表进行描述,在后期不需要添加新的主属性,那么一定会减少很多可压缩的调试时间。

在开发技术方面,这次尝试了 Python 的 Web 框架 Django 作为后端的 Web 应用,后端的数据库使用了 Django 推荐的 SQLite ,虽然不适合实际生产环境,但是便于上手,也使得我们能够在系统的其他地方进行一点点细节上的打磨,前端使用了 Bootstrap4 + jQuery 来开发。

在开发前期,许多时间用在了前端的细节优化上,通过 Bootstrap 将界面统一风格,也因此将管理页面中订单和上菜提醒直观表现出来,不需要进入二级菜单就能将上菜信息传达上来。在后期逐渐将数据存储所需的约束与触发操作完善,使得各个关系合理存在。

这次数据库课设对我们来说是一个综合能力的考验,也是将数据库系统与所学知识的结合,通过这次课设,我对数据库设计能力有了很大提高,也学会了在应用中引入数据库、维护数据库,不过所体现的问题也是以后需要不断学习、实践的地方。

8 参考文献

[1] 范长青. 智能点菜系统设计开发与引用[J].微型电脑应用. 2019-06-14 [2] 石爱好. 基于 SQL Server 2012 数据库的应用及研究[J].电脑迷. 2017(03) [3] 单立娟. 数据库技术在移动点菜系统上的应用[J].数字技术与应用. 2016-08-15 [4] 于卓立,刘沙沙,苏家鹏,宋文苑,邹晓琳. 智能餐桌系统设计与实现[J].电脑编程技术与维护. 2014-12-18 [5] 李源. 餐厅点菜系统的设计与实现[J].电子技术与软件工程. 2015-10-16 [6] 王欣. 智能电子点菜系统的研究[J].北京交通大学. 2017-06-01 [7] 尹亮. 餐厅点菜及后厨系统的设计与实现[J].电子科技大学. 2015-03-15

界面截图


主界面

点菜界面

后厨界面

管理界面

餐桌负责状态表中绿色表示有订单,红色表示后厨已经做好了菜,处于等待上菜阶段。

餐桌和上菜信息每 30 秒和每 10 秒动态刷新,仅刷新指定区域。

点击负责人可切换该桌负责人。

订单管理界面

点击订单号进入订单详情,绿色代表已支付订单,红色代表未支付订单。

订单详情界面

批量结账界面

点击单条订单可进入相应订单详情页。

菜品管理界面

使用


cd FoodOrder
python manage.py runserver

完整代码:https://download.csdn.net/download/qq_38735017/87415895

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/197685.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

皮尔森相关系数(Pearson correlation coefficient)

最近在看脑机接口的网络,看到有使用通道的皮尔森相关系数作为特征的方法,这里记录一下皮尔森相关系数的学习内容,方便以后查阅。 皮尔森相关系数(Pearson correlation coefficient)相关系数简单相关系数复相关系数典型相关系数参考…

【MySQL】MySQL中的数学函数有哪些?

数学函数MySQL函数简介数学函数1.绝对值函数ABS(x)和返回圆周率的函数PI()2.平方根函数SQRT(x)和求余函数MOD(x,y)3.获取整数的函数CEIL(x)、CEIL…

关于Json Web Token(token)在前后端的实践思考

1、前言 啥也不说了,直接进入正题,来学习一下Token在前端和后端的简单应用分析 Token是在客户端频繁向服务端请求数据,服务端频繁的去数据库查询用户名和密码进行对比,判断用户名和密码是否正确,并作出相应提示&…

华为机试题:HJ37 统计每个月兔子的总数(python)

文章目录博主精品专栏导航知识点详解1、input():获取控制台(任意形式)的输入。输出均为字符串类型。1.1、input()与list(input())的区别、及其相互转换方法2、print() :打印输出。3、整型int() :将字符串或数字转换为整…

C语言基础(二)—— 常量与变量、数据类型、进位制、关键字、原码反码补码、限定符、字符串格式化输入输出

1. 常量与变量1.1 关键字1.2 数据类型数据类型的作用:编译器预算对象(变量)分配的内存空间大小。1.3 常量在程序运行过程中,其值不能被改变的量常量一般出现在表达式或赋值语句中整型常量100,200,-100&…

MySQL事务篇

目录​​​​​​​ 一.事务有哪些特性? 二.并行事务会引发什么问题? 脏读 不可重复读 幻读 三.事务的隔离级别有哪些? 一.事务有哪些特性? 原子性(Atomicity):一个事务中的所有操作&…

4.数据库安全性

学习过程参考(后续章节同) 【公开课】数据库系统概论(王珊老师)(完结) 《数据库系统概论》思维导图 【专栏必读】数据库系统概论第五版(王珊)专栏学习笔记目录导航及课后习题答案详…

2023年02月IDE流行度最新排名

点击查看最新IDE流行度最新排名(每月更新) 2023年02月IDE流行度最新排名 顶级IDE排名是通过分析在谷歌上搜索IDE下载页面的频率而创建的 一个IDE被搜索的次数越多,这个IDE就被认为越受欢迎。原始数据来自谷歌Trends 如果您相信集体智慧&am…

MySQL的函数

目录 一.分类 聚合函数 概述 格式 操作 数学函数 操作1 操作2 操作3 字符串函数 操作1 操作2 操作3 操作4 日期函数 操作1 操作2 操作3 控制流函数 if逻辑判断语句 case when 语句 窗口函数 介绍 分类 序号函数 开窗聚合函数- SUM,AVG,MIN,MAX 分布函数-…

Java 对象拷贝与转换-org.mapstruct:mapstruct 包(@Mapper、@Mapping)的使用

MapStruct的使用 最近在学习技术时候,发现一个特别好用的包,org.mapstruct:mapstruct,它是专门用来处理 domin 实体类与 model 类的属性映射的 它的优势: 很多项目大量映射的方式通过手动get、set,首先写法很low&…

并发编程 · 基础篇 · android线程那些事

小木箱成长营并发编程系列教程(排期中): 并发编程 基础篇(下) android线程池那些事 并发编程 提高篇(上) Java并发关键字那些事 并发编程 提高篇(下) Java锁安全性那些事 并发编程 高级篇(上) Java内存模型那些事 并发编程 高级篇(下) Java并发BATJ面试之谈 并发编程…

Jupyter notebook——在Anaconda中多个环境下,设置不同的默认打开路径

项目背景:anaconda中搭建了一个python3.6,一个python3.7版本,python3.6环境版本的jupyter notebook默认打开路径设置为:D:\DeepLearning\cv,修改jupyter notebook默认路径见:https://blog.csdn.net/qq_1881…

分享115个图片切换JS特效,总有一款适合您

分享115个图片切换JS特效,总有一款适合您 115个图片切换JS特效下载链接:https://pan.baidu.com/s/1QX7b5LDlY6lBqMVjgBKSwA?pwdk05d 提取码:k05d Python采集代码下载链接:https://wwgn.lanzoul.com/iKGwb0kye3wj jQuery多图…

Appium+Python+pytest自动化测试框架

先简单介绍一下目录,再贴一些代码,代码里有注释Basic目录下写的是一些公共的方法,Data目录下写的是测试数据,image存的是测试失败截图,Log日志文件,Page测试的定位元素,report测试报告&#xff…

Linux从入门到精通

Linux从入门到精通 1. Linux 简介 Linux 内核最初只是由芬兰人林纳斯托瓦兹(Linus Torvalds)在赫尔辛基大学上学时出于个人爱好而编写的。 Linux 是一套免费使用和自由传播的类 Unix 操作系统,是一个基于 POSIX(可移植操作系统接…

Nacos 注册监听器

文章目录前言项目文件说明pom依赖bootstrap.ymlNacosConfig 配置类监听器实现类-默认实现监听器实现类-json配置处理注册监听器监听器的效果前言 本文主要讨论Nacos作为配置中心时,其中配置内容发生更改时,我们的应用程序能够做的事。 一般使用监听器来…

DeepLabV3+:Mobilenetv2的改进以及浅层特征和深层特征的融合

目录 Mobilenetv2的改进 浅层特征和深层特征的融合 完整代码 参考资料 Mobilenetv2的改进 在DeeplabV3当中,一般不会5次下采样,可选的有3次下采样和4次下采样。因为要进行五次下采样的话会损失较多的信息。 在这里mobilenetv2会从之前写好的模块中…

第四天链表

24. 两两交换链表中的节点力扣题目链接(opens new window)给定一个链表,两两交换其中相邻的节点,并返回交换后的链表。你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换。接下来就是交换相邻两个元素了,此时一定要画…

vite --- 为什么选Vite

目录 什么是Vite 为什么选Vite 现实问题 为什么生产环境仍需打包 Vite 与竞品 什么是Vite Vite(法语意为 "快速的",发音 /vit/,发音同 "veet")是一种新型前端构建工具,能够显著提升前端开发体…

SpringBoot+Vue图书馆管理系统1.0

简介:本项目采用了基本的SpringBootVue设计的图书馆管理系统。详情请看截图。经测试,本项目正常运行。本项目适用于Java毕业设计、课程设计学习参考等用途。 项目描述 项目名称SpringBootVue图书馆管理系统1.0源码作者LHL项目类型Java EE项目 &#xff…