首页 > 其他分享 >Mybatis框架中结果映射resultMap标签方法属性收录

Mybatis框架中结果映射resultMap标签方法属性收录

时间:2024-06-15 17:04:16浏览次数:13  
标签:Java 映射 resultMap user Mybatis id 属性

Mybatis框架中结果映射resultMap标签收录

在MyBatis框架中,resultMap 是一种强大的机制,用于将数据库结果集映射到Java对象上。它允许你定义如何将查询结果中的列映射到Java对象的属性上,尤其是当数据库表的字段名与Java对象的属性名不一致时,或者需要进行复杂的映射(如一对一、一对多关系)时,resultMap 就显得尤为重要。

1. 基本结构

一个基本的resultMap定义如下:

<resultMap id="userResultMap" type="User">
  <id property="id" column="user_id"/>
  <result property="username" column="user_name"/>
  <result property="password" column="user_password"/>
</resultMap>

在这个例子中:

  • id 属性定义了resultMap的唯一标识符。
  • type 属性指定了映射到的Java类型。
  • idresult 元素用于定义主键和普通属性的映射。
  • property 属性是Java对象的属性名。
  • column 属性是数据库表的列名。

2. 方法使用

select语句中使用resultMap

<select id="selectUserById" resultMap="userResultMap">
  SELECT user_id, user_name, user_password FROM users WHERE user_id = #{id}
</select>

在这个select语句中,resultMap属性引用之前定义的userResultMap

3. 高级映射

resultMap 还支持更复杂的映射,如关联(association)、集合(collection)、鉴别器(discriminator)等。

关联(Association)

用于一对一关系的映射:

<resultMap id="orderResultMap" type="Order">
  <id property="id" column="order_id"/>
  <result property="orderNumber" column="order_number"/>
  <association property="user" javaType="User">
    <id property="id" column="user_id"/>
    <result property="username" column="user_name"/>
  </association>
</resultMap>
集合(Collection)

用于一对多关系的映射:

<resultMap id="userResultMapWithOrders" type="User">
  <id property="id" column="user_id"/>
  <result property="username" column="user_name"/>
  <collection property="orders" ofType="Order">
    <id property="id" column="order_id"/>
    <result property="orderNumber" column="order_number"/>
  </collection>
</resultMap>

4. 方法总结

回顾概念
  • ID:在resultMap中,可以为每个映射指定一个唯一的ID,以便于引用。
  • Result:基本的结果映射,可以指定列名和对象属性名之间的映射关系。
  • Association:用于处理一对一的关系映射。例如,一个订单(Order)对象关联一个用户(User)对象。
  • Collection:用于处理一对多的关系映射。例如,一个用户(User)对象关联多个订单(Order)对象。
  • Discriminator:用于处理类的继承关系映射,根据数据库中的某个字段值来决定实例化哪个子类。

resultMap 是MyBatis中用于处理复杂数据映射的关键特性。通过定义resultMap,可以灵活地将数据库中的数据映射到Java对象上,处理不同命名规则、复杂关系等问题。正确使用resultMap可以大大提高数据访问层的灵活性和可维护性。

image-20240614100908507

示例演示

假设有一个用户表(users)和一个订单表(orders),用户表中有用户ID(user_id)、用户名(username),订单表中有订单ID(order_id)、用户ID(user_id, 作为外键)和订单详情(details)。

本示例过程中我们要实现从订单表查询订单的同时,也获取到该订单对应的用户信息。

首先,在MyBatis的映射文件中定义一个resultMap:

1<resultMap id="OrderResultMap" type="com.example.Order">
2    <id property="orderId" column="order_id"/>
3    <result property="details" column="details"/>
4    
5    <!-- Association映射,用来处理一对一关系 -->
6    <association property="user" javaType="com.example.User">
7        <id property="userId" column="user_id"/>
8        <result property="username" column="username"/>
9    </association>
10</resultMap>

然后,在查询语句中引用这个resultMap:

1<select id="selectOrderWithUser" resultMap="OrderResultMap">
2    SELECT o.order_id, o.details, u.user_id, u.username
3    FROM orders o
4    LEFT JOIN users u ON o.user_id = u.user_id
5</select>

这样,当执行这个查询时,MyBatis会自动根据OrderResultMap中定义的映射规则,将查询结果转换成Order对象,并且正确地将关联的用户信息填充到Order对象的user属性中。

了解更多知识请戳下:

@Author:懒羊羊

标签:Java,映射,resultMap,user,Mybatis,id,属性
From: https://blog.csdn.net/kangqiao0422/article/details/139704696

相关文章

  • springboot+vue+mybatis家电系统+PPT+论文+讲解+售后
    随着信息互联网购物的飞速发展,一般企业都去创建属于自己的电商平台以及购物管理系统。本文介绍了家电销售系统的开发全过程。通过分析企业对于家电销售系统的需求,创建了一个计算机管理家电销售系统的方案。文章介绍了家电销售系统的系统分析部分,包括可行性分析等,系统设计部分主......
  • mybatis之特殊SQL的执行
    1.1模糊查询尝试://模糊查询用户List<User>getUserByLike(@Param("mohu")Stringmohu);<selectid="getUserByLike"resultType="user">select*fromuserwhereusernamelike'%#{mohu}%'</select>@Testpub......
  • springboot+vue+mybatis基于java的物资综合管理系统的设计与实现+PPT+论文+讲解+售后
    如今社会上各行各业,都喜欢用自己行业的专属软件工作,互联网发展到这个时候,人们已经发现离不开了互联网。新技术的产生,往往能解决一些老技术的弊端问题。因为传统物资综合管理系统信息管理难度大,容错率低,管理人员处理数据费工费时,所以专门为解决这个难题开发了一个物资综合管理系......
  • Java最全知识脑图 涵盖 juc mysql git mybatis 等 面试必备
    Java初中级知识脑图面试超实用1.Git下载链接导图下载地址:https://mm.edrawsoft.cn/mobile-share/index.html?uuid=31d00742157057-src&share_type=12.JUC下载链接https://mm.edrawsoft.cn/mobile-share/index.html?uuid=6c0be457444921-src&share_type=13.JVM下载链......
  • mybatisplus一个入参查询两个字段用或
    1List<TechnologyParamPackageMaterialVo>materialVoList=newArrayList<>();23LambdaQueryWrapper<TechnologyParamPackage>wrapper=newLambdaQueryWrapper<>();4wrapper.eq(ObjUtil.isNotEmpty(queryReq.getStatus()),TechnologyPara......
  • SpringBoot集成MyBatis-Plus
    SpringBoot集成MyBatis-Plus代码生成器背景​ MyBatis-Plus代码生成器相较于MyBatis代码生成器,可以多生成controller层和service层,并且配置更丰富,通过对Freemarker默认模板的修改和增加自定义模板配置适配,可提升开发效率操作步骤项目目录结构MyFreemarkerTemplateEngine继......
  • 详细描述MyBatis缓存的实现原理?
    MyBatis是一个优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。MyBatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集。MyBatis可以使用简单的XML或注解进行配置和映射原始类型、接口和Java的POJO(PlainOldJavaObjects,普通的Java对象)为数据库中......
  • 使用MyBatis的注意事项有哪些
    这篇文章给大家分享的是有关使用MyBatis的注意事项有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、MyBatis的HelloWord1.根据xml配置文件(全局配置文件mybatis-config.xml)创建一个SqlSessionFactory对象有数据源一些运行环境信息<?xml ve......
  • kubernetes-外部数据库服务映射至集群内-Service与Endpoints的关系
    创建yaml文件配置数据库信息kind:ServiceapiVersion:v1metadata:name:mysql-svcnamespace:ops-systemspec:type:ClusterIP #Kubernetes将为此服务随机分配一个集群内部的IP地址ClusterIP类型的服务只能在集群内部访问,提供了一个内部访问的固定IP地址,不对......
  • MyBatis之工作原理,简单CRUD,一篇让你明白原理
    一、MyBatis之工作原理MyBatis是一个半自动映射框架。所谓半自动,是相对Hibernate全表映射而言的,MyBatis需要手动匹配提供POJO、SQL和映射关系。我们知道,jdbc有四个核心对象(1)DriverManager,用于注册数据库连接(2)Connection,与数据库连接对象(3)Statement/PrepareStatement,操作数......