一、公共字段自动填充
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文件: