mybatis多字段一对多嵌套查询

mybatis或mybatis-plus嵌套查询语句,嵌套查询条件为多字段。

1. 定义JavaBean

@Data
@Accessors(chain = true)
@ApiModel(value = "WflowLogTableEntityDto", description = "工作流调度日志数据传输")
public class WflowLogTableEntityDto {
    @ApiModelProperty(value="执行批次ID")
    @TableId(value = "exec_id", type = IdType.INPUT)
    private String execId;
    @ApiModelProperty(value="工作流ID")
    @TableField("wflow_id")
    private String wflowId;
    // 省略...这里本来有很多字段的,暂时省略

    @ApiModelProperty(value="子流程节点日志")
    @TableField(exist = false)
    private List<WflowLogdetailTableEntityDto> nodes;
}

 

2. 定义mapper.xml查询

<resultMap id="WflowLogTableEntityDtoMap"
               type="com.xxx.dto.WflowLogTableEntityDto">
        <id column="exec_id" property="execId"/>
        <id column="wflow_id" property="wflowId"/>
        <collection property="nodes"
                    ofType="com.xxx.dto.WflowLogdetailTableEntityDto"
                    javaType="ArrayList"
                    column="{wflowId=wflow_id, execId=exec_id }"
                    select="com.xxx.mapper.IWflowLogdetailTableMapper.getWflowNodeLogDetail"
         >
        </collection>
    </resultMap>

多字段嵌套查询定义column="{wflowId=wflow_id, execId=exec_id }",其中wflowId,execId为嵌套接口的绑定的字段名字,如下图蓝色框框中的字段名,

wflow_id和exec_id 为外层接口的返回字段名。通过外层的返回结果相应的字段值,绑定到嵌套的接口查询,查询嵌套的结果集。

公司项目,隐藏了部分内容

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值