Mybatis高效连表查询:association与collection实践

需积分: 5 0 下载量 135 浏览量 更新于2024-08-03 收藏 8KB MD 举报
"Mybatis连表查询中的association与collection是两种处理多对多关联关系的重要机制。在进行数据库操作时,特别是在处理具有多个关联表的查询时,这两个标签能够帮助简化代码并提高效率。 首先,让我们了解association标签。当你在结果映射(resultMap)中使用`<association>`元素时,它允许你在子查询的结果集中嵌入另一个resultMap。例如,在给定的代码中,`EmpDept`实体类继承了`EmpMapper.BaseResultMap`,并且在`EmpDeptResultMap`中,`<association property="dept" resultMap="com.example.hello.dao.DeptMapper.BaseResultMap">`这部分表示`EmpDept`对象的`dept`属性将引用`Dept`对象。这意味着查询结果中的每个`EmpDept`对象都将包含一个完整的`Dept`对象实例,而无需在`EmpDept`类中再次列出所有`Dept`的属性。这样做的好处是减少了代码冗余,并且当`Dept`表的结构发生变化时,仅需更新`DeptMapper`的结果映射,而`EmpDeptMapper`的映射保持不变,提高了代码的可维护性。 `extends`属性在此处的作用是复用已存在的基础映射,避免了重复编写映射规则。如果`BaseResultMap`在不同命名空间下,需要明确指定命名空间,这样可以更好地组织和管理代码。 接下来是collection标签。与association类似,collection用于处理一对多或多对多的关系,但它会将关联对象以列表形式返回,而不是单个对象。然而,这里的例子没有直接展示collection的使用,因为`selectEmpDept`方法返回的是`List<EmpDept>`,这表明查询结果已经被组织成了`EmpDept`对象的集合,每个元素都有一个`dept`属性,所以在这里可能隐含了collection的概念。 在实际测试代码部分,`@Autowired EmpDeptMapper empDeptMapper`注解表明Spring Boot的依赖注入已经将`EmpDeptMapper`注入到了测试类中。`selectEmpDept`方法调用`empDeptMapper`执行SQL查询,返回的是一个`List<EmpDept>`,表明查询结果符合我们预期的关联结构。 总结来说,Mybatis的association和collection提供了灵活的方式来处理多对多和一对多关系,通过合理的映射配置,可以显著减少代码量,提高代码的可维护性和扩展性。理解并熟练运用这两个标签对于编写高效、清晰的数据库查询至关重要。"