本文主要是介绍MyBatis关联元素(association)处理“有一个”类型的关系(关联的嵌套结果、关联的嵌套查询),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
有两种方法处理这种问题:
1、关联的嵌套查询
2、关联的嵌套结果
网上关于这两个方法的详细使用方法和示例有很多,读者可自行上网搜索,推荐文档,在这里就不详细讲解。
在这里我主要是讲一下第一种方法中使用时注意的一个问题:
示例:(引用来自推荐的文章里)
<resultMap id="blogResult" type="Blog"><association property="author" column="author_id" javaType="Author" select="selectAuthor"/> </resultMap><select id="selectBlog" resultMap="blogResult">SELECT * FROM BLOG WHERE ID = #{id} </select><select id="selectAuthor" resultType="Author">SELECT * FROM AUTHOR WHERE ID = #{id} </select>
以上示例中背景为红色的部分 ID=#{id}中id应该是数据库表格中查询出来的列的名称还是Author对象的属性名称呢?起初我对于这个问题也是不知道,后来经过试验,id选填列名称和Author对象id的属性名称都行。出现这样的结果,也不知道是我的程序坏了,还是真的两个名称都行。因为本人对mybatis理解较为浅显,如果有路过的大神知道是我的程序错了或者内部原因,欢迎赐教。
这篇关于MyBatis关联元素(association)处理“有一个”类型的关系(关联的嵌套结果、关联的嵌套查询)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!