2 wulongbang7370 wulongbang7370 于 2016.04.30 13:43 提问

请问为什么我的mybatis 关联查询只有一条记录,但是日志打印出来的Total: 3, 谢谢

SELECT * FROM JiKeUser;
这个里面有如下三条记录,

     id  userName   password  
------  ---------  ----------
     2  jike00100  666666    
     3  jike00200  888888    
     8  author001  123456    

SELECT * FROM author;
这个里面也是三条记录,

     id  realName      userID  IDCard  
------  ------------  ------  --------
     1  一个大牛               8  (NULL)  
     2  bbb                2  (NULL)  
     3  aaaaaa             3  (NULL)  

这样关联查询自然也是三条,

 SELECT * FROM author INNER JOIN jikeUser 
            ON jikeuser.id=author.userID ;

在java中的映射也就是author对象中有个引用指向jikeuser,

 public class Author {
    private Integer id; //自增主键
    private JiKeUser jikeUser; //外键引用JiKeUser表
    private String realName;//真实姓名
    private String IDCard;//身份证

可是我用如下方法查询却只查询出来一个记录,
这是配置文件


    <resultMap id="JiKeAuthorMap" type="Author">
        <id property="id" column="author.id" />
        <result property="realName" column="realName" />
        <result property="IDCard" column="IDCard" />
        <association property="jikeUser" column="userID"
            javaType="JiKeUser">
            <id property="id" column="jikeUser.id" />
            <result property="userName" column="userName" />
            <result property="password" column="password" />
        </association>
    </resultMap>

    <select id="selectAuthorJoin" resultMap="JiKeAuthorMap">
        select * from author inner join jikeUser 
            on jikeuser.id=author.userID
    </select>
下面是java代码
    List<Author> ap=session.selectList("selectAuthorJoin");//联合查询 
            System.out.println(ap.size());   //1
但是如下的日志里面的total倒是对的,是3,
    2016-04-30 05:33:43,781 [main] DEBUG [/.selectAuthorJoin] - ==>  Preparing: select * from author inner join jikeUser on jikeuser.id=author.userID 
  2016-04-30 05:33:43,806 [main] DEBUG [/.selectAuthorJoin] - ==> Parameters: 
  2016-04-30 05:33:43,819 [main] DEBUG [/.selectAuthorJoin] - <==      Total: 3

可就是查询出来的list的size就是1个啊,郁闷

4个回答

zmcmm
zmcmm   2016.04.30 16:04

不要select*,把别名加上试试

wulongbang7370
wulongbang7370   2016.04.30 19:37

select * from author join jikeUser
on jikeuser.id=author.userID, 要修改要什么别名啊,谢谢

fk002008
fk002008   2016.04.30 23:43

首先呢你的数据库查询出来是3条而且程序也没有报错,
因此你的别名什么的是ok的

既然java中取出的是一条那么就是说明这个xml中的map有问题了。



                    第一行有这个jikeUser但是后面的没有
            你不妨把列名加上和这个resultmap中的东西对应起来
fk002008
fk002008 id property="id" column="author.id" 下面的没有加这个author.
一年多之前 回复
wulongbang7370
wulongbang7370 不好意思,这个csdn 真是够bug的,我几下回车就变这样了 ,我如下做了还是不行, <select id="selectAuthorJoin" resultMap="JiKeAuthorMap"> select author.id,realName,IDCard,jikeUser.id,username,password from author join jikeuser on jikeuser.id=author.userID </select> 还有啊,你说的‘ 第一行有这个jikeUser但是后面的没有‘是什么意思啊’’
一年多之前 回复
wulongbang7370
wulongbang7370 谢谢,我如下做了还是不行,
一年多之前 回复
wulongbang7370
wulongbang7370 谢谢,我如下做了还是不行,
一年多之前 回复
u014427391
u014427391   2016.05.01 00:34
Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!