Spring Boot实训项目 瑞吉外卖功能实现(一)

简介: Spring Boot实训项目 瑞吉外卖功能实现

1 实训基本信息

1.1 实训项目名称

“外卖点餐”系统。

1.2 实训时间及地点

2 实训内容简介

本项目(“外卖点餐”系统)是专门为餐饮企业(餐厅、饭店)定制的-款软件产品,包括系统管理后台和移动端应用两部分。

其中系统管理后台主要提供给餐饮企业内部员工使用,可以对餐厅的菜品、套餐、订单等进行管理维护。移动端应用主要提供给消费者使用,可以在线浏览菜品、添加购物车、下单等。

3 需求分析

3.1 软硬件条件

IDEA 2021.2.3

MySQL 5.5

MyBatis

MyBatisPlus

Git: 版本控制工具。

Maven: 3.6.1

Junit:单元测试工具。

3.2 技术可行性

3.2.1 技术需求

外卖点单、支付、订单管理、配送等功能是瑞吉外卖必不可少的技术需求。此外,还需要提供用户注册、登录、反馈、推荐等功能。

3.2.2 市场需求

外卖市场的需求是巨大的,但竞争也是非常激烈的。应该进行市场细分,并确定与众不同的商业模式和目标用户,同时提供具有差异化的服务和体验。

3.2.3 开发成本

应该评估开发瑞吉外卖应用所需的成本,包括技术设计、软件工程、移动端应用开发、数据分析等方面。

3.2.4 数据连通性

外卖应用需要和多个配送和支付供应商的应用进行连接,确保订单的顺利传递和支付的正确处理。

3.2.5 用户体验

好的用户体验是被用户所赞赏和记住的重要要素。外卖应用中,用户体验包括易用、快速、准确、方便等多个方面。

4 功能设计

4.1 管理端

4.1.1 登录/退出

内部员工必须登录后,才可以访问系统管理后台。

4.1.2 员工管理

管理员可以在系统后台对员工信息进行管理,包含查询、新增、编辑、禁用等功能。

4.1.3 分类管理

主要对当前餐厅经营的菜品分类或套餐分类进行管理维护,包含查询、新增、修改、删除等功能。

4.1.4 菜品管理

主要维护各个分类下的菜品信息,包含查询、新增、修改、删除、启售、停售等功能。

4.1.5 套餐管理

主要维护当前餐厅中的套餐信息,包含查询、新增、修改、删除、启售、停售等功能。

4.1.6 订单明细

主要维护用户在移动端下的订单信息,包含查询、取消、派送、完成,以及订单报表下载等功能。

4.2 用户端

4.2.1 登录/退出

在移动端, 用户也需要登录后使用APP进行点餐。

4.2.2 点餐-菜单

在点餐界面需要展示出菜品分类/套餐分类, 并根据当前选择的分类加载其中的菜品信息, 供用户查询选择。

4.2.3 点餐-购物车

用户选中的菜品就会加入用户的购物车, 主要包含查询购物车、加入购物车、删除购物车、清空购物车等功能。

4.2.4 订单支付

用户选完菜品/套餐后, 可以对购物车菜品进行结算支付, 这时就需要进行订单的支付。

4.2.5 个人信息

在个人中心页面中会展示当前用户的基本信息, 用户可以管理收货地址, 也可以查询历史订单数据。

5 数据库设计

用户表

字段

数据类型

主键

外键

是否为空

说明

Id

bigint(20)

Name

varchar(50)

姓名

Phone

varchar(100)

手机号

Sex

varchar(2)

性别

Id_number

varchar(18)

身份证号

Avatar

Status

varchar(500)

int(11)

头像

状态

购物车表

字段

数据类型

主键

外键

是否为空

说明

Id

bigint(20)

Name

varchar(50)

名称

Image

varchar(100)

图片

User_id

bigint(20)

用户ID

Dish_Id

bigint(20)

菜品ID

Setmeal_Id

DishFlavor

bigint(20)varchar(50)

套餐ID

口味

Number

int(11)

数量

Amount

CreateTime

decimal(10)

datetime

金额

创建时间

地址薄表

字段

数据类型

主键

外键

是否为空

说明

Id

bigint(20)

User_Id

bigint(20)

用户ID

Consignee

varchar(50)

收货人

Sex

tinyint(4)

性别

Phone

Province

varchar(11)

varchar(12)

手机号

省级编号

Province

Varchar(32)

省级名称

City_code

City_name

varchar(12)

varchar(32)

市级编号

市级名称

District

varchar(12)

区级编号

District

varchar(32)

区级名称

Detail

varchar(200)

详细地址

Label

varchar(100)

标签

Is_default

tinyint(1)

是否默认

Createtime

datetime

创建时间

Updatetime

datetime

更新时间

Createuser

Bigint(20)

创建者

Updateuser

Bigint(20)

修改者

Is_deleted

int(11)

是否删除

分类表

字段

数据类型

主键

外键

是否为空

说明

Id

bigint(20)

Type

int(11)

类型

Name

varchar(64)

名称

Sort

int(11)

顺序

CreateTime UpdateTime

datetime

datetime

创建时间

更新时间

Createuser

bigint(20)

创建者

Updateuser

bigint(20)

修改者

菜品表

字段

数据类型

主键

外键

是否为空

说明

Id

bigint(20)

Name

varchar(64)

菜品名称

CategoryId

bigint(20)

菜品分类ID

Price

decimal(10)

菜品价格

Code

varchar(64)

商品码

Image

Descripte

varchar(200)

varchar(400)

图片

描述信息

Status

int(11)

状态码

Sort

int(11)

顺序

CreateTime UpdateTime

datetime

datetime

创建时间

更新时间

Createuser

Bigint(20)

创建者

Updateuser

Bigint(20)

修改者

Is_deleted

int(11)

是否删除

口味表

字段

数据类型

主键

外键

是否为空

说明

Id

bigint(20)

Dish_Id

bigint(20)

菜品ID

Name

varchar(64)

口味名称

Value

varchar(500)

口味数据

CreateTime UpdateTime

datetime

datetime

创建时间

更新时间

Createuser

Bigint(20)

创建者

Updateuser

Bigint(20)

修改者

Is_deleted

int(11)

是否删除

员工表

字段

数据类型

主键

外键

是否为空

说明

Id

bigint(20)

Name

varchar(32)

姓名

Username

varchar(32)

用户名

Password

varchar(64)

密码

Phone

varchar(11)

手机号

Sex

varchar(2)

性别

Id_Number

varchar(18)

身份证号

Status

Int(11)

状态

CreateTime UpdateTime

datetime

datetime

创建时间

更新时间

Createuser

Bigint(20)

创建者

Updateuser

Bigint(20)

修改者

订单表

字段

数据类型

主键

外键

是否为空

说明

Id

bigint(20)

Number

varchar(50)

订单号

Status

Int(11)

订单状态

User_Id

bigint(20)

下单用户

Address_id

bigint(20)

地址ID

Order_Time CheckTime

datetime

datetime

下单时间

结账时间

Pay_method

int(11)

支付方式

Amount

decimal(10)

实收金额

Remark

varchar(100)

备注

Phone

varchar(255)

手机号

Address

varchar(255)

用户地址

User_name

varchar(255)

用户名

Consignee

varchar(255)

收货人

订单详情表

字段

数据类型

主键

外键

是否为空

说明

Id

bigint(20)

Name

varchar(50)

名称

Image

varchar(100)

图片

Order_Id

bigint(20)

订单ID

Dish_Id

bigint(20)

菜品ID

Setmeal_Id

DishFlavor

bigint(20)

varchar(50)

套餐ID

口味

Number

int(11)

数量

Amount

decimal(10)

金额

套餐表

字段

数据类型

主键

外键

是否为空

说明

Id

bigint(20)

CategoryId

bigint(20)

分类ID

Name

varchar(64)

套餐名称

Price

decimal(10)

套餐价格

Status

Int(11)

状态

Code

varchar(32)

编码

Descripte

varchar(512)

描述信息

Image

varchar(255)

图片

CreateTime UpdateTime

datetime

datetime

创建时间

更新时间

Createuser

Bigint(20)

创建者

Updateuser

Bigint(20)

修改者

Is_Delete

varchar(50)

是否删除

分类表

菜品表

口味表

员工表

目录
打赏
0
1
0
0
17
分享
相关文章
微服务——SpringBoot使用归纳——Spring Boot中的项目属性配置——少量配置信息的情形
本课主要讲解Spring Boot项目中的属性配置方法。在实际开发中,测试与生产环境的配置往往不同,因此不应将配置信息硬编码在代码中,而应使用配置文件管理,如`application.yml`。例如,在微服务架构下,可通过配置文件设置调用其他服务的地址(如订单服务端口8002),并利用`@Value`注解在代码中读取这些配置值。这种方式使项目更灵活,便于后续修改和维护。
15 0
微服务——SpringBoot使用归纳——Spring Boot使用slf4j进行日志记录——使用Logger在项目中打印日志
本文介绍了如何在项目中使用Logger打印日志。通过SLF4J和Logback,可设置不同日志级别(如DEBUG、INFO、WARN、ERROR)并支持占位符输出动态信息。示例代码展示了日志在控制器中的应用,说明了日志配置对问题排查的重要性。附课程源码下载链接供实践参考。
41 0
微服务——SpringBoot使用归纳——Spring Boot中的项目属性配置——指定项目配置文件
在实际项目中,开发环境和生产环境的配置往往不同。为简化配置切换,可通过创建 `application-dev.yml` 和 `application-pro.yml` 分别管理开发与生产环境配置,如设置不同端口(8001/8002)。在 `application.yml` 中使用 `spring.profiles.active` 指定加载的配置文件,实现环境快速切换。本节还介绍了通过配置类读取参数的方法,适用于微服务场景,提升代码可维护性。课程源码可从 [Gitee](https://gitee.com/eson15/springboot_study) 下载。
27 0
微服务——SpringBoot使用归纳——Spring Boot中的项目属性配置——少量配置信息的情形
在微服务架构中,随着业务复杂度增加,项目可能需要调用多个微服务。为避免使用`@Value`注解逐一引入配置的繁琐,可通过定义配置类(如`MicroServiceUrl`)并结合`@ConfigurationProperties`注解实现批量管理。此方法需在配置文件中设置微服务地址(如订单、用户、购物车服务),并通过`@Component`将配置类纳入Spring容器。最后,在Controller中通过`@Resource`注入配置类即可便捷使用,提升代码可维护性。
18 0
Spring Boot中的项目属性配置
本节课主要讲解了 Spring Boot 中如何在业务代码中读取相关配置,包括单一配置和多个配置项,在微服务中,这种情况非常常见,往往会有很多其他微服务需要调用,所以封装一个配置类来接收这些配置是个很好的处理方式。除此之外,例如数据库相关的连接参数等等,也可以放到一个配置类中,其他遇到类似的场景,都可以这么处理。最后介绍了开发环境和生产环境配置的快速切换方式,省去了项目部署时,诸多配置信息的修改。
【SpringBoot】项目属性配置
【SpringBoot】项目属性配置
150 0
SpringBoot(二)_项目属性配置
修改端口 在main/resources/application.properties修改端口 server.port=8088 此时启动访问localhost:8088/hello 就会看到 Hello Spring Boot! 使用yml文件替换properties 文件 (1)在main/resources 文件下新建一个application.
1252 0
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——基于 xml 的整合
本教程介绍了基于XML的MyBatis整合方式。首先在`application.yml`中配置XML路径,如`classpath:mapper/*.xml`,然后创建`UserMapper.xml`文件定义SQL映射,包括`resultMap`和查询语句。通过设置`namespace`关联Mapper接口,实现如`getUserByName`的方法。Controller层调用Service完成测试,访问`/getUserByName/{name}`即可返回用户信息。为简化Mapper扫描,推荐在Spring Boot启动类用`@MapperScan`注解指定包路径避免逐个添加`@Mapper`
29 0
微服务——SpringBoot使用归纳——Spring Boot集成Thymeleaf模板引擎——Thymeleaf 介绍
本课介绍Spring Boot集成Thymeleaf模板引擎。Thymeleaf是一款现代服务器端Java模板引擎,支持Web和独立环境,可实现自然模板开发,便于团队协作。与传统JSP不同,Thymeleaf模板可以直接在浏览器中打开,方便前端人员查看静态原型。通过在HTML标签中添加扩展属性(如`th:text`),Thymeleaf能够在服务运行时动态替换内容,展示数据库中的数据,同时兼容静态页面展示,为开发带来灵活性和便利性。
33 0

热门文章

最新文章