mybatis 多表查询

一对一:

第一:在一中的类添加另外一个类作为属性。如(在Order类中添加private User orderUser;)

第二:在mapper.xml配置关联。(mapper接口不变)

XML 复制代码
<!-- resultMap标签:解决查询结果字段名和实体类属性名不致的问题;  解决多表查询关联映射 -->
    <resultMap id="orderMap" type="实体类(全限定名)">
        <!--配置:查询结果和Order类的映射关联 -->
        <id column="实体类id" property="id"></id>
        <result column="字段" property="实体类字段"></result>

        <!-- 配置:1对1查询
             配置 : 查询结果和User类的映射关联
             autoMapping="true"表示字段与属性实体类名字相同自动复制。
             如果遇到不相同的用<result></result>关联
        -->
        <association property="mapper中函数返回值类型" javaType="属性实体类(全限定名)" autoMapping="true">
            <id column="属性实体id" property="id"></id>
            <result column="属性实体表中字段名" property="属性实体中属性名"></result>
        </association>userName
    </resultMap>

    <!-- 根据订单编号,查询订单信息及下单人信息 -->
    <select id="mapper中函数名" resultMap="mapper中函数返回值类型">
        <!-- 双表联查。 -->
    </select>

一对多

第一:在一中的类添加另外一个类作为集合属性。如(在User(一)类中添加

private List<Order> orders(多);)

第二:在mapper.xml配置关联。(mapper接口不变)

XML 复制代码
 <!--配置多表查询映射关系-->
    <resultMap id="mapper函数返回值" type="实体类(一)全限定名" autoMapping="true">
        <!--配置: 查询结果和User类的映射-->
        <id column="表(一)id字段" property="实体类id"></id>
        <result column="字段" property="实体类(一)属性"></result>

        <!--配置:1对多关系-->
        <collection property="实体类(多)"
                    javaType="java.util.List"
                    ofType="实体类(多)全限定名">
            <!--配置:查询结果和Order类的映射-->
            <id column="表(多)id字段" property="实体类(多)id"></id>
            <result column="表(多)字段名" property="实体类(多)属性"></result>
        </collection>
    </resultMap>


    <!--根据用户id,查询用户信息和下单信息-->
    <select id="mapper函数名" resultMap="mapper函数返回值">
  <!--连表查询。-->
    </select>
相关推荐
敲代码的彭于晏2 分钟前
Bean 生命周期完全图解:前端同学也能看懂的 Spring 核心机制
java·前端·后端
IT_陈寒8 分钟前
Redis内存飙升的锅,原来是我没搞懂这个过期策略
前端·人工智能·后端
云浪15 分钟前
前端二进制数组完全指南:ArrayBuffer、TypedArray、DataView 一次讲透
前端·javascript
张风捷特烈17 分钟前
Flutter 类库大揭秘#02 | path_provider 各平台实现
前端·flutter
铁皮饭盒1 小时前
26年bunjs, elysia+pg一把梭, redis都省了
前端·javascript·后端
plainGeekDev1 小时前
ButterKnife → ViewBinding
android·java·kotlin
lichenyang45314 小时前
Docker 学习笔记(一):为什么需要镜像、容器和仓库?
前端
kyriewen14 小时前
别再对着 TypeScript 报错发呆了:我把 10 个最常见的红色波浪线翻译成了人话
前端·javascript·typescript
IT_陈寒14 小时前
SpringBoot自动配置的坑,我的API突然就404了
前端·人工智能·后端