Mybatis结果集映射(一) 对象嵌套对象

   如果mybatis查询返回的对象中里面还嵌套着其它对象,那么就需要结果集映射。
   例如我们要从数据库表中查询ExportOperationsVo的id, operationTime, operator.userId和receiver.userId。

实体类:

public class ExportOperationsVo {
	private String id;
	private ExportUserVo operator;  //嵌套ExportUserVo对象
	private Date operationTime;
    private ExportUserVo receiver;  //嵌套ExportUserVo对象
    }
public class ExportUserVo {
	private String userId;
	private String username;
	private String departmentId;
	private String departmentName;
	}

dao层接口:

 public ExportOperationsVo getExportOperationsVoById(@Param("id") String id);

XML:

<select id="getExportOperationsVoById"
		resultMap="ExportOperationMap">
		select
		id,
		src_operator_id,
		des_operator_id,
		operation_time,
		from operation_table
		where id=#{id}
	</select>
	<resultMap id="ExportOperationMap"
		type="ExportOperationsVo的全限定类名">
		<result column="id" property="id" />
		<!--operation_time为数据库表字段,对应ExportOperationsVo的operationTime属性-->
		<result column="operation_time" property="operationTime" />
		<association property="receiver"
			javaType="ExportUserVo全限定类名">
			<result column="des_operator_id" property="userId" />
		</association>
		<!--des_operator_id为数据库表字段,对应receiver的userId属性-->
		<association property="operator"
			javaType="ExportUserVo全限定类名">
			<result column="src_operator_id" property="userId" />
		</association>
	</resultMap>

注意resultMap中要按照 的顺序写,不然会报错

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值