在Springboot+Mybatis-plus不使用SQL语句进行多表添加操作
我所遇到的问题
我们都知道,在我们使用Mybatis-plus中进行多表操作是极其困难的,如果你不使用Mybatis-plus-join这一类的工具,你只能去配置对应的Mapper.xml文件,配置又臭又长的ResultMap,然后再去写对应的sql语句,这种方法虽然看上去很麻烦,但具有很高的灵活性,可以让我们更灵活的修改甲方需要的功能.
但是如果我将要做一个很普通的小项目,不需要什么灵活的变动,并且我不想去写SQL语句,想直接用Mybatis-plus的功能来实现多表(一主多副)数据的添加,那我该怎么做呢?
观看数据库可以知道,我们有商品表,然而商品对于商品图片,商品参数和商品类型都是一对多或者多对一的关系,但是我想要我们的前端可以直接提交一个表单就能完成多个表中数据的添加,多表操作是必然的了
准备工作
因为此操作之前我已经使用了mybatis-plus-join的多表查询操作,所以我已经生成了一个DTO的实体类
@Data
public class BrandDTO {
private Integer id;
//类型表
private String type;
//商品表
private String brandName;
private String companyName;
private String description;
//图片链接表
private List<Img> imgUrlList;
//参数表
private List<Parameter> parameterList;
}
在这个类中你会疑惑 : 为什么我不直接封装一个Brand实体对象进来呢?
因为我之前使用了这个类来进行连表查询,把各个实体类的参数分开放进来(竟然没有重名的 hhhh),并且这个类需要做展示,所以我把Brand类的属性原原本本加入进来,而tpye对应Brand应该是多(type)对一(Brand),所以在这里我也只封装了一个,但由于Brand对于Img和Parameter是一对多的关系,所以我把他们封装成为了一个list<对象>,就这样我们得到了一个类似于中间类的东西
在测试环境下模拟
我们不妨想一下,有了这样的一个类,我们只需要把参数分开添加到各个表中,我们需要想象我们得到一个封装有数据的BrandDTO的对象,然后拆解开来使用各自的mapper接口的方法来进行插入表格行为
(首先接口要继承对应的BaseMapper<>,才可以进行快速操作,当然如果你在接口有对应的添加方法也可以,但是既然我们用了mybatis-plus,为什么还要拐回去自己写添加方法?)
于是,经过几次反复实验,我得到了如下测试方法:
@Test
public void addBrand(){
Brand brand = new Brand();
Type type = new Type();
Img img = new Img();
Parameter parameter = new Parameter();
BrandDTO brandDTO = new BrandDTO();
brandDTO.setBrandName("测试商品3");
brandDTO.setCompanyName("厂家3");
brandDTO.setDescription("这是第二个个测试");
brandDTO.setType("第Ⅱ型");
List<Img> imgs =new ArrayList<