在MyBatis中,一对多关系可以通过两种方法进行数据添加:
使用嵌套查询: 首先,在映射文件中定义两个相应的查询语句,一个查询主表数据,一个查询从表数据。然后,在主表的查询语句中使用嵌套查询从表的查询语句,通过主表的主键与从表的外键建立关联。最后,在业务逻辑中调用主表的查询语句,MyBatis会自动执行嵌套查询并将结果映射为嵌套对象。
示例代码如下:
<!-- 主表查询语句 -->
<select id="getMainTableData" resultMap="MainTableResultMap">
SELECT *
FROM main_table
</select>
<!-- 从表查询语句 -->
<select id="getSubTableData" resultMap="SubTableResultMap">
SELECT *
FROM sub_table
WHERE main_table_id = #{id}
</select>
<!-- 主表映射 -->
<resultMap id="MainTableResultMap" type="MainTable">
<!-- 主表字段映射 -->
</resultMap>
<!-- 从表映射 -->
<resultMap id="SubTableResultMap" type="SubTable">
<!-- 从表字段映射 -->
</resultMap>
在业务逻辑中调用查询语句:
MainTable mainTable = sqlSession.selectOne("getMainTableData", id);
MyBatis会自动执行嵌套查询并将结果映射为嵌套对象。
使用association和collection标签: 另一种方法是使用MyBatis的association和collection标签。在映射文件中,使用association标签定义主表和从表的关联关系,并使用collection标签定义从表的集合。然后,在业务逻辑中调用主表的查询语句,MyBatis会自动执行关联查询并将结果映射为关联对象。
示例代码如下:
<!-- 主表查询语句 -->
<select id="getMainTableData" resultMap="MainTableResultMap">
SELECT *
FROM main_table
</select>
<!-- 主表映射 -->
<resultMap id="MainTableResultMap" type="MainTable">
<!-- 主表字段映射 -->
<association property="subTable" resultMap="SubTableResultMap"/>
</resultMap>
<!-- 从表映射 -->
<resultMap id="SubTableResultMap" type="SubTable">
<!-- 从表字段映射 -->
</resultMap>
在业务逻辑中调用查询语句:
MainTable mainTable = sqlSession.selectOne("getMainTableData", id);
MyBatis会自动执行关联查询并将结果映射为关联对象。