前言
有好一阵没碰mybatis了,这次的项目基于性能考虑,选了mybatis,写着写着,发现有下面的需求,比如两表联查,取其中各一部分字段,怎么更方便地用vo来接,这里犯了难;
我想的是,因为这个sql联查的vo,能不能直接使用两个表的po来接呢,比如下面这种:
Users、SeatInformation都是对应了数据库两张表的po
@Data
public class UserSeatUnionQueryVO {
private Users users;
private SeatInformation seatInformation;
}
折腾了2个小时,网上各种找不到类似需求,终于搞出来了,还是值得记录和分享。
一、两表关联,映射到如下类型vo(拷贝单表po属性,组合另一单表的po),怎么写
sql:
假设我想映射的vo如下:
@Data
public class UserSeatUnionQueryVO {
/**
* 用户Id
*/
@ApiModelProperty(value = "用户Id")
@TableId(value = "user_id", type = IdType.ID_WORKER)
private Long userId;
/**
* 账号状态,-1停用,1启用
*/
@ApiModelProperty(value = "账号状态,-1停用,1启用")
private Integer accountStatus;
/**
* 这里的SeatInformation是表seat_information对应的po
*/
private SeatInformation seatInformation;
}
则mapper中应该这样写:
UsersMapper.xml
SeatInformationMapper.xml:
//省略无关代码
二、两表关联,映射到如下类型vo(组合两表po),怎么写
上面的方案呢,假设A关联B,在vo里,相当于是把B组合进了A;我想的是,能不能新建一个vo,同时组合A和B呢,比如下面这样:
@Data
public class UserSeatUnionQueryVO {
private Users users;
private SeatInformation seatInformation;
}
sql:
和方案一一样。
UsersMapper.xml:
注意这里的 association
元素中的resultMap
字段,引用了其他Mapper
文件的BaseResultMap
格式是:其他Mapper
文件的namespace
,加上resultMap
的名字。
这里附上SeatInformationMapper.xml
的内容:
//省略无关
下面附上完整的usersMapper.xml
的内容:
展示下效果:
可以看到,最后这种,这么写没问题。
三、官网文档
我在官网看了半天,后来才找到类似的例子:
https://mybatis.org/mybatis-3/sqlmap-xml.html
因为文档很长,上面这个图,大家可以通过打开上面的网址后,搜索 Multiple ResultSets for Association
到达该位置。