大家好,我是烤鸭:
今天分享一下关于mybatis的级联查询。
环境:
mybatis 3.2.8
spring 4.1.9
在一个人申请某些账号或者权限的时候,比如微信的认证流程。
会让你一步一步按要求输入,比如第一步:点击微信认证,第二步:认证联系人信息填写;最后一步:填写公众号名称、功能介绍、选择运营地区就。
当你在填写完第二步退出之后,再重新登录会发现第一步的信息已经记录了。
这里至少要设计四张表,流程表和每一步的表,都是主键一一关联,这是一对一。
又或者如其他平台的企业版的认证,可以添加下级的机构,这就是一对多了。
get,set方法是必须要的,我这里没粘贴出来。
public class ApplyCompanyBackResp{
private static final long serialVersionUID = 1L;
private ApplyCompanyBusinessA businessA1;
private ApplyCompanyBusinessAl businessAl;
private ApplyCompanyBusinessCt businessC1;
private ApplyCompanyBusinessCr businessC2;
private ApplyCompanyBusinessJ businessAliantJ1;
private ApplyCompanyBusinessM businessM1;
private ApplyCompanyBusinessMo businessAliantM2;
private List businessJ1StoreList;
}
从sql我们可以看出来,有一张process主表,其他的表都是以applyId作为主键关联。其中store表是一对多的关系,其他都是一对一。如果我们想把这个企业的所有权限信息展示,就需要关联这些所有的表。
需求是查询这些权限的状态,所以不需要太多其他的字段。
association 中的 property 对应的是 resultMap实体中的属性名称,在上面就是这个ApplyCompanyBackResp。
ApplyCompanyBackResp 这个pojo中的属性名称,比如 businessA1 对应的 property 就是 businessA1。
column 是一定要写的 ,对应的是数据库的关联字段名称,比如上边的是apply_id 。
返回的实体类型。
数据库表主键,我这边是主键关联,所以id就是apply_id。property 是 实体属性 ,column是 查询的结果字段(别名)。比如上边的各种status,是起的别名,这里要和下边的 column 对应上。
针对于我这边不需要查询主键,可以不查。
和id是一样的, 是非主键的字段映射。property 是 实体属性 ,column是 查询的结果字段(别名)。
association 中的 property 对应的是 resultMap实体中的属性名称,在上面就是这个ApplyCompanyBackResp。
ApplyCompanyBackResp 这个pojo中的属性名称,比如 businessJ1StoreList对应的 property 就是 businessJ1StoreList。
返回的实体类型。
数据库表主键,我这边是主键关联,所以id就是apply_id。property 是 实体属性 ,column是 查询的结果字段(别名)。比如上边的各种status,是起的别名,这里要和下边的 column 对应上。
针对于我这边不需要查询主键,可以不查。
和id是一样的, 是非主键的字段映射。property 是 实体属性 ,column是 查询的结果字段(别名)。
mybatis的级联查询,如果是一对一,一定在 association标签内加 column属性。这样查询出来的才能封装到 结果对象 中。
如果是一对多,mysql查询出来的数据结果就会是多条。比如上面的情况,查询出来的结果如果是2条,这两条数据collection前面的结果是一样的,只是针对于collection中的属性名称的 结果 不一样。类似下图,应该j1Name,j1StoreStatus 这列是从别的表查询出来的,其他列数据是相同的。
如果你想清晰一点你的话,也可以在 association 或者 collection 写 select标签,值是 select 语句。类似下图