Java苍穹外卖02-公共字段自动填充-菜品管理

news2024/10/5 19:09:09

一、公共字段自动填充

1.问题分析

需要有一种手段能够在mapper层(持久层)知道当前操作是否是insert或者update。
为mapper中需要进行拦截的方法加注解,然后去为这些赋值

2.代码开发

注解创建:

注意这里的Retention注解一定要是RUNTIME不然进入不了切面,设置value为OperationType枚举,规定这个注解只能是对INSERT和UPDATE两个操作进行处理。

切面类:

创建切面类:

设置切入点:

对mapper包下*所有的类.*类中所有的方法(..)所有属性以及这些方法中有AutoFill注解的方法

前置通知:

获取当前方法操作数据库类型-就是从注解中获取是什么OperationType:

这里的signature是反射中的知识,获得签名对象后获得了AutoFill的注解

获取当前被拦截的方法参数-就是获取实体对象:

这里的joinpoint是AOP中的知识,可以获取切入点处的传入参数

准备赋值数据:

根据不同的操作类型,为对应属性赋值:

因为为了泛化性,这里采用反射获取实体对象的类中的方法,再invoke方法为其赋值,这样无论传入的实体是什么只要有相应名称的set方法就可以统一填充公共字段。

二、新增菜品

1.需求分析

涉及三个接口

2.代码开发

①文件上传接口

阿里云OSS配置:

为什么采用动态的写法,因为可能要更换环境oss配置就不一样了,可以直接在application.yml中进行切换

这里需要有一个AliOssUtil工具类的对象交给IOC容器,我们就可以直接在controller中注入
创建一个配置类,加上Bean注解,将aliOssProperties中的值传入创建AliOssUtil工具类bean对象

controller:

upload方法将传入的路径文件,文件名UUID,以及获得bytes数组,请求AliOss获得url

②新增菜品接口:

controller:

service:

菜品有口味,且一个菜品不止一个口味,首先插入菜品除口味的数据,口味放在dish_flavor中,用逻辑外键关联

dishMapper xml文件:
这里的useGeneratedkeys设置为true说明返回自动生成的主键,keyProperty返回到对象的什么字段上要保持一致

因为菜品口味表中该菜品的主键是菜品插入后才会有的,所以要返回主键值

dishFlavorMapper xml文件:

这里采用动态插入,遍历了集合。

三、菜品分页查询

1.需求分析

2.代码开发

query请求参数,放在地址栏一value?形式传进来不用加注解、

controller:

service:

mapper xml文件:

注意这里是多表查询,因为分类名称在分类表中才有,返回的DishVO中。
这里是左外连接查询,会将左边表独有的字段和与右边表共有的字段返回。

四、删除菜品

1.需求分析

这样就可以删除一个或多个,如果想直接接受到List组合的id,就需要加RequestParam注解

分类和菜品是一对多,分类和套餐也是一对多,套餐和菜品是多对多需要有中间表,所以删除菜品还得看中间表中的数据。菜品和口味是一对多。

2.代码开发

controller:

service:

根据主键查询是否起售,起售不能删除抛出异常,以及是否存在套餐中,根据菜品的id动态查询在关系表中是否存在数据

删除数据

套餐菜品关系表查询xml文件:

删除数据xml文件:

dish:

dish_flavor:

五、修改菜品

1.需求分析

2.代码开发

根据id查询菜品:

controller:

service:

需要根据菜品id查询菜品基本信息和口味信息,并封装到dishVO对象中去

修改菜品:

controller:

service:

这里update是动态更新传什么值才修改什么,下面口味信息的修改是删除原口味再添加新口味。

update xml文件:

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

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

相关文章

MySQL—MySQL的存储引擎之InnoDB

MySQL—MySQL的存储引擎之InnoDB 存储引擎及种类 存储引擎说明MyISAM高速引擎,拥有较高的插入,查询速度,但不支持事务InnoDB5.5版本后MySQL的默认数据库存储引擎,支持事务和行级锁,比MyISAM处理速度稍慢ISAMMyISAM的…

Unity AssetsBundle打包

为什么要使用AssetsBundle包 减少安装包的大小 默认情况下,unity编译打包是对项目下的Assets文件夹全部内容进行压缩打包 那么按照这个原理,你的Assets文件夹的大小将会影响到你最终打包出的安装包的大小,假如你现在正在制作一个游戏项目&…

Apollo 7周年大会:百度智能驾驶的展望与未来

本心、输入输出、结果 文章目录 Apollo 7周年大会:百度智能驾驶的展望与未来前言百度集团副总裁、智能驾驶事业群组总裁王云鹏发言 直播回放大会相关内容先了解 Apollo开放平台 9.0架构图 发布产品Apollo 定义自己对于智能化的认知百度集团副总裁 王云鹏…

阿斯达年代记三强争霸服务器没反应 安装中发生错误的解决方法

阿斯达年代记三强争霸服务器没反应 安装中发生错误的解决方法 最近刚上线的由影视剧改编的游戏《阿斯达年代记三强争霸》可谓是在游戏圈内引起了轩然大波,这是一款由网石集团与龙工作室联合开发的MMORPG游戏,游戏背景设定在一个名为阿斯大陆的区域&…

Java之复制图片

从文件夹中复制图片 从这个文件夹: 复制到这个空的文件夹: 代码如下: import java.io.*; import java.util.Scanner;/*** 普通文件的复制*/public class TestDome10 {public static void main(String[] args) {// 输入两个路径// 从哪里(源路…

IOMMU和SMMU详解

前言: IOMMU(输入输出内存管理单元)的原理与CPU中的MMU(内存管理单元)相似。它的作用是管理设备的内存访问请求,允许安全、高效地在设备和内存之间直接传输数据。IOMMU通常用于支持高速数据传输的设备&…

了解时间复杂度和空间复杂度

在学习数据结构前,我们需要了解时间复杂度和空间复杂度的概念,这能够帮助我们了解数据结构。 算法效率分为时间效率和空间效率 时间复杂度 一个算法的复杂度与其执行的次数成正比。算法中执行基础操作的次数,为算法的时间复杂度。 我们采…

墨水屏技术在工业智能化领域的创新应用

墨水屏技术在工业智能化领域的创新应用 随着科技的快速发展,各种显示技术层出不穷,其中墨水屏作为一种独特的显示技术,逐渐在工业领域展现出其独特的优势和价值。墨水屏以其低功耗、高对比度和阅读舒适度高等特点,正成为工业应用…

9【PS作图】像素画Tips

放大缩小 “窗口”-排列-为…画布新建窗口,就可以新建一个窗口,实时看作图效果 如果要保持放大或缩小的像素画仍然保持硬边缘,需要设置两个东西 将 编辑 > 首选项 > 常规 中的 插值方式 改为 “邻近(靠近硬边缘&#xff09…

android脱壳第二发:grpc-dumpdex加修复

上一篇我写的dex脱壳,写到银行类型的app的dex修复问题,因为dex中被抽取出来的函数的code_item_off 的偏移所在的内存,不在dex文件范围内,所以需要进行一定的修复,然后就停止了。本来不打算接着搞得,但是写了…

Hadoop伪分布式平台搭建

搭建Hadoop伪分布式环境是在单台机器上模拟完整的Hadoop分布式系统,使得所有的Hadoop守护进程(如NameNode、DataNode、ResourceManager、NodeManager等)都在同一台机器上运行。这样可以在一台机器上体验Hadoop的分布式特性,适合学…

openWebUI+ollamawindows+不用docker+webLite本地安装

openWebUI & ollama & windows & 不用docker & webLite 本地安装 总结一下安装教程 10核CPU16G内存 两个web框架都可以,先说简单的 ollama-webui-lite(https://github.com/ollama-webui/ollama-webui-lite) 轻量级,只使用nodejs 先装…

RTK负载(4K可见光+高分热成像+超广角+激光测距)四光AI智能识别跟踪吊舱技术详解

无人机光电吊舱的RTK负载(4K可见光高分热成像超广角激光测距)AI智能识别跟踪吊舱技术是一种高度集成和先进的无人机观测系统。系统结合了无人机的飞行能力和光电吊舱的多功能传感器,通过集成RTK(实时动态差分定位)技术…

php 编译安装oracel扩展

第一步安装Oracle客户端 1,需要下载基础包和sdk oracle客户端下载链接:Oracle Instant Client Downloads for Linux x86-64 (64-bit) https://www.oracle.com/database/technologies/instant-client/linux-x86-64-downloads.html 选择最新版本 versi…

【智能算法】向日葵优化算法(SFO)原理及实现

目录 1.背景2.算法原理2.1算法思想2.2算法过程 3.结果展示4.参考文献 1.背景 2019年,GF Gomes等人受到自然界向日葵运动行为启发,提出了向日葵优化算法(Sunflower Optimization, SFO)。 2.算法原理 2.1算法思想 SFO模拟向日葵行…

数据库原理与应用实验二 SQL SERVER查询分析器的使用

实验目的和要求 熟悉SQL SERVER环境,熟悉查询分析器的使用,能够熟练运用sql命令完成数据库,基本表、主码、外码和其它必要的约束条件的定义。 实验环境 Windows10 SQLServer 实验内容与过程 1 利用sql建立图书管理数据库,并定…

勒索软件安全防护手册

文章目录 相关背景勒索软件概述勒索软件主要类型文件加密类勒索软件数据窃取类勒索软件系统加密类勒索软件。屏幕锁定类勒索软件 勒索软件典型传播方式利用安全漏洞传播利用钓鱼邮件传播利用网站挂马传播利用移动介质传播利用软件供应链传播利用远程桌面入侵传播 典型勒索软件攻…

string的OJ题

1.字符串相加 给定两个字符串形式的非负整数 num1 和num2 ,计算它们的和并同样以字符串形式返回。 你不能使用任何內建的用于处理大整数的库(比如 BigInteger), 也不能直接将输入的字符串转换为整数形式。 思路:从字…

区块链技术与应用学习笔记(10-11节)——北大肖臻课程

目录 10.分岔 ①什么是分叉? ②导致分叉的原因? ③在比特币新共识规则发布会会导致什么分叉? 什么是硬分叉? 硬分叉例子? 什么是软分叉? 软分叉和硬分叉区别? 软分叉实例 11.问答 转…

【java数据结构-优先级队列向下调整Topk问题,堆的常用的接口详解】

🌈个人主页:努力学编程’ ⛅个人推荐:基于java提供的ArrayList实现的扑克牌游戏 |C贪吃蛇详解 ⚡学好数据结构,刷题刻不容缓:点击一起刷题 🌙心灵鸡汤:总有人要赢,为什么不能是我呢 …