做码农不如养猪 2021-10-26 09:47 采纳率: 50%
浏览 89
已结题

在数据库的Sql语句能查询出多条,但在mybatis只返回一条,语句相同

具体代码如下:

sql:
SELECT aid,acontent,adate,like_count,ui.uid AS uid,wid,nickname,portrait,
        (SELECT COUNT(1) FROM bug_answer WHERE FIND_IN_SET(aid,get_answerSon_list(11)) AND wid != 0) AS `count`
        FROM bug_answer ba JOIN user_info ui ON ba.uid = ui.uid WHERE bid = 11 AND wid = 0

==此时是能查询出多条的==

mybatis
<!-- 查询指定Bug文章下的回答集合 -->
    <select id="findAllBugAnswerByBid" resultMap="findAllBugAnswerMap">
        SELECT aid as aid,acontent,adate,like_count,ui.uid AS uid,wid,nickname,portrait,
        (SELECT COUNT(1) FROM bug_answer WHERE FIND_IN_SET(aid,get_answerSon_list(ba.aid)) AND wid != 0) AS `count`
        FROM bug_answer ba JOIN user_info ui ON ba.uid = ui.uid WHERE bid = #{bid} AND wid = #{wid}
    </select>
mybatis 映射:
<!-- 回答 与 用户 联通映射 -->
    <resultMap id="findAllBugAnswerMap" type="com.talentscout.vo.BugAnswerAndUserInfo">
         <result property="count" column="count"/>
         <association property="bugAnswer" javaType="com.talentscout.pojo.bug.BugAnswer">
             <result property="aid" column="aid"/>
             <result property="aContent" column="aContent"/>
             <result property="aDate" column="aDate"/>
             <result property="like_count" column="like_count"/>
             <result property="uid" column="uid"/>
             <result property="wid" column="wid"/>
         </association>
         <association property="userInfo" javaType="com.talentscout.pojo.user.UserInfo">
             <result property="nickName" column="nickName"/>
             <result property="portrait" column="portrait"/>
         </association>
    </resultMap>
实体
@Data
@ToString
public class BugAnswerAndUserInfo {
    private BugAnswer bugAnswer; // 回答实体
    private int count; // 子回复数量
    private UserInfo userInfo; // 用户信息实体
    private UserInfo userInfoSon; // 子用户信息实体
}
测试
    @Override
    public List<BugAnswerAndUserInfo> findAllBugAnswerByBid(Integer bid, Integer wid) {
        for (BugAnswerAndUserInfo bugAnswerAndUserInfo : bugMainMapper.findAllBugAnswerByBid(bid, wid)) {
            System.out.println(bugAnswerAndUserInfo.toString());
        }
        return bugMainMapper.findAllBugAnswerByBid(bid,wid);
    }
结果
BugAnswerAndUserInfo(bugAnswer=BugAnswer(aid=32, aContent=WebSocket yyds!, aDate=Tue Oct 26 06:15:13 CST 2021, like_count=0, bid=0, uid=NO_2, wid=0), count=0, userInfo=UserInfo(uid=null, nickName=勇敢牛牛, age=0, sex= , register_date=null, brief=null, direaction=null, collective=null, portrait=t2.jpg), userInfoSon=null)

最离谱的是我特喵没动,之前是能查询出来的,莫名其妙就只查询出一条了

  • 写回答

6条回答 默认 最新

  • BCS-点心 2021-10-26 09:50
    关注

    Integer bid, Integer wid
    这两个参数传的对不对

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(5条)

报告相同问题?

问题事件

  • 系统已结题 11月3日
  • 已采纳回答 10月26日
  • 创建了问题 10月26日

悬赏问题

  • ¥15 飞机曲面部件如机翼,壁板等具体的孔位模型
  • ¥15 vs2019中数据导出问题
  • ¥20 云服务Linux系统TCP-MSS值修改?
  • ¥20 关于#单片机#的问题:项目:使用模拟iic与ov2640通讯环境:F407问题:读取的ID号总是0xff,自己调了调发现在读从机数据时,SDA线上并未有信号变化(语言-c语言)
  • ¥20 怎么在stm32门禁成品上增加查询记录功能
  • ¥15 Source insight编写代码后使用CCS5.2版本import之后,代码跳到注释行里面
  • ¥50 NT4.0系统 STOP:0X0000007B
  • ¥15 想问一下stata17中这段代码哪里有问题呀
  • ¥15 flink cdc无法实时同步mysql数据
  • ¥100 有人会搭建GPT-J-6B框架吗?有偿