mybatis级联查询,多对一查询问题

在使用Mybatis进行多表级联查询时遇到了一个问题:查询结果只有一项,但正确结果是两项。经测试,SQL语句本身没有问题。

在SQL映射文件(XML)中:

<!-- 级联查询数据 -->
    <resultMap id="resultUserOhter" type="Uother">
        <id column="id" property="id"  />
        <result column="other" property="other"  />
        <association property="user" javaType="User">
            <id column="id"  property="id" />
            <result column="name" property="name" />
            <result column="info" property="info" />
        </association>
    </resultMap>
    <select id="getUserOhters" parameterType="int" resultMap="resultUserOhter">
        select
         user.id,user.name,user.info,uother.id,uother.ohter from uother,user
        where user.id=uother.user_id
    </select>

经过试验,这种现象原因是id的问题,使用resultMap进行结果映射的时候其id作为主键,应该唯一,即上面的这种结构的嵌套只能映射多个Uother对应一个User的情况。如果查询结果的Uother的id重复则只保留一项(可能是最后一项)。总之,查询结果中<id>对应的属性值必须是唯一的。

再次查询可查询到多项数据。

 

posted @ 2017-04-21 20:47  esCharacter  阅读(885)  评论(0编辑  收藏  举报