文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

怎么解决mybatis一对多查询resultMap只返回了一条记录问题

2023-06-21 21:33

关注

本篇内容介绍了“怎么解决mybatis一对多查询resultMap只返回了一条记录问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

问题描述:因为领导的一个需求,需要用到使用resultMap,很久没使用了,结果就除了点意外。就记录下这个问题
准备两个类:author(作者)和book(书),数据库创建对应的author->book一对多的数据

@Datapublic class Author {    private Integer id;    private String name;    private String phone;    private String address;    private List<Book> books;}@Datapublic class Book {    private Integer id;    private String name;    private String press;    private BigDecimal price;    private Integer authorId;}

开始的Mapper.xml文件

<resultMap id="bookMap" type="com.example.demo.dto.Author">        <id column="id" property="id"></id>        <result column="name" property="name"></result>        <result column="address" property="address"></result>        <result column="phone" property="phone"></result>        <collection property="books" ofType="com.example.demo.dto.Book">            <id column="id" property="id"></id>            <result column="name" property="name"></result>            <result column="press" property="press"></result>            <result column="price" property="price"></result>            <result column="author_id" property="authorId"></result>        </collection>    </resultMap>    <select id="queryAuthorInfo" parameterType="java.lang.String" resultMap="bookMap">        select t1.*,t2.* from        author t1 inner join book t2 on t1.id=t2.author_id        where t1.id=#{id}    </select>

使用postman执行查看结果:

{    "code": "200",    "msg": "成功",    "data": {        "id": 1,        "name": "法外狂徒张三",        "phone": null,        "address": null,        "books": [            {                "id": 1,                "name": "法外狂徒张三",                "press": "人民出版社",                "price": 10.00,                "authorId": 1            }        ]    }}

发现问题:本来author对应book有两条记录,结果books里面只返回了一条记录。
问题原因:2张表的主键都叫id,所以导致结果不能正确展示。
解决方法:1、主键使用不用的字段名。2、查询sql时使用别名
1、主键使用不用的字段名,涉及到更改数据库,只需要更改其中一个即可 。这里演示将book的id更改为book_id

<resultMap id="bookMap" type="com.example.demo.dto.Author">        <id column="id" property="id"></id>        <result column="name" property="name"></result>        <result column="address" property="address"></result>        <result column="phone" property="phone"></result>        <collection property="books" ofType="com.example.demo.dto.Book">            <!---更改book类的id为bookId,数据库book的id更改为book_id-->            <id column="book_id" property="bookId"></id>            <result column="name" property="name"></result>            <result column="press" property="press"></result>            <result column="price" property="price"></result>            <result column="author_id" property="authorId"></result>        </collection>    </resultMap>    <select id="queryAuthorInfo" parameterType="java.lang.String" resultMap="bookMap">        select t1.*,t2.* from        author t1 inner join book t2 on t1.id=t2.author_id        where t1.id=#{id}    </select>

查询sql时使用别名。这里演示将查询book时id 更改别名为 bookId

<resultMap id="bookMap" type="com.example.demo.dto.Author">        <id column="id" property="id"></id>        <result column="name" property="name"></result>        <result column="address" property="address"></result>        <result column="phone" property="phone"></result>        <collection property="books" ofType="com.example.demo.dto.Book">            <!---这里将column值id更改为别名一致bookId-->            <id column="bookId" property="id"></id>            <result column="name" property="name"></result>            <result column="press" property="press"></result>            <result column="price" property="price"></result>            <result column="author_id" property="authorId"></result>        </collection>    </resultMap>    <select id="queryAuthorInfo" parameterType="java.lang.String" resultMap="bookMap">        <!---这里新增了t2.id as bookId-->        select t1.*,t2.id as bookId, t2.* from        author t1 inner join book t2 on t1.id=t2.author_id        where t1.id=#{id}    </select>

“怎么解决mybatis一对多查询resultMap只返回了一条记录问题”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯