展厅设计说明200字/科学新概念seo外链平台

展厅设计说明200字,科学新概念seo外链平台,高端的家居行业网站开发,wordpress utc时间设置引言 <resultMap> 是 MyBatis 中最核心的映射配置元素&#xff0c;用于解决数据库字段与 Java 对象属性之间的复杂映射问题&#xff0c;尤其是字段名不一致、嵌套对象关联、集合映射等场景。ResultMap 的设计思想是&#xff0c;对简单的语句做到零配置&#xff0c;对于复…

引言

<resultMap> 是 MyBatis 中最核心的映射配置元素,用于解决数据库字段与 Java 对象属性之间的复杂映射问题,尤其是字段名不一致、嵌套对象关联、集合映射等场景。ResultMap 的设计思想是,对简单的语句做到零配置,对于复杂一点的语句,只需要描述语句之间的关系就行了。以下是 <resultMap> 的详细解析和用法说明。


一、<resultMap> 基础结构

1. 核心属性
  • id:唯一标识符,用于其他操作引用此映射。
  • type:映射的目标 Java 对象类型(全限定类名或别名)。
  • autoMapping:是否启用自动映射(默认 false,建议部分场景开启)。
    在这里插入图片描述
2. 基础示例

场景:数据库字段为 user_id,Java 对象属性为 userId

<!-- 
用户结果映射(基础版本)
功能:将数据库查询结果映射到com.example.User对象
说明:1. id="BaseUserMap":标识这个结果映射的唯一名称。2. type="com.example.User":指定目标Java对象的完整类路径。3. <id property="userId" column="user_id">:定义主键属性userId与数据库列user_id的映射关系。4. <result property="userName" column="user_name">:定义普通属性userName与数据库列user_name的映射关系。5. <result property="age" column="age">:定义普通属性age与数据库列age的映射关系。
用法:在需要复杂映射的场景下,可复用此结果映射。-->
<resultMap id="BaseUserMap" type="com.example.User"><id property="userId" column="user_id" /><result property="userName" column="user_name" /><result property="age" column="age" />
</resultMap><!-- 
查询用户基本信息
功能:从users表中查询user_id、user_name和age列,并使用BaseUserMap结果映射转换为Java对象
说明:1. id="getUser":标识这个查询操作的唯一名称。2. resultMap="BaseUserMap":指定使用BaseUserMap结果映射来处理查询结果。3. SELECT user_id, user_name, age FROM users:从users表中查询指定列。
用法:在Mapper接口中定义对应的方法,例如:User getUser();返回一个包含用户基本信息的User对象。-->
<select id="getUser" resultMap="BaseUserMap">SELECT user_id, user_name, age FROM users
</select>

二、字段映射详解

1. <id><result> 的区别
  • <id>:标记主键字段,影响缓存和性能优化(必须配置)。
  • <result>:普通字段映射。
    在这里插入图片描述
2. 显式映射 vs 自动映射
  • 显式映射:手动配置所有字段(推荐复杂场景)。
  • 自动映射:开启 autoMapping="true" 后,未配置的字段按名称自动映射。
<!-- 
自动映射主键的用户结果映射
功能:使用MyBatis的自动映射功能,将数据库查询结果映射到User对象
特别说明:1. autoMapping="true":表示开启MyBatis的自动映射功能。- MyBatis会自动将查询结果中与User对象属性名匹配的列映射到对应的属性上。2. <id property="userId" column="user_id">:手动配置主键映射,确保主键列与User对象的userId属性正确对应。- 通常主键列需要显式定义,其他非主键列可以依赖自动映射完成。-->
<resultMap id="AutoUserMap" type="User" autoMapping="true"><id property="userId" column="user_id" /> <!-- 只需配置主键 -->
</resultMap><!-- 
查询用户信息(使用自动映射)
功能:从users表中查询所有用户信息,并通过AutoUserMap结果映射转换为User对象。
特别说明:- 该查询语句只需简单地从表中选择所有列(SELECT *),因为开启了自动映射,MyBatis会自动处理列名与User对象属性的映射。- 如果某些列名与User对象属性名不一致,可以手动在resultMap中配置对应的映射关系。-->
<select id="getUser" parameterType="String" resultMap="AutoUserMap">SELECT * FROM users
</select>

三、关联关系映射

1. 一对一关联 <association>

场景:用户(User)与身份证(IDCard)一对一关联。
Java 对象

public class User {private Integer userId;private String userName;private IDCard idCard; // 一对一对象
}

映射配置

<!-- 
用户与身份证信息的结果映射
功能:将用户信息和其关联的身份证信息映射到User对象
说明:1. id="UserWithIDCardMap":标识这个结果映射的唯一名称。2. type="User":指定目标Java对象类型为User。3. <id property="userId" column="user_id">:定义User对象的userId属性与数据库表的user_id列对应,作为主键。4. <result property="userName" column="user_name">:定义User对象的userName属性与数据库表的user_name列对应。5. <association property="idCard" javaType="IDCard">- property="idCard":User对象中的idCard属性,表示用户的身份证信息。- javaType="IDCard":指定关联对象的Java类型为IDCard。- <id property="cardId" column="card_id">:定义IDCard对象的cardId属性与数据库表的card_id列对应,作为主键。- <result property="cardNumber" column="card_number">:定义IDCard对象的cardNumber属性与数据库表的card_number列对应。- 通过这个关联映射,可以将用户的身份证信息嵌套到User对象中。-->
<resultMap id="UserWithIDCardMap" type="User"><id property="userId" column="user_id"/><result property="userName" column="user_name"/><!-- 嵌套对象映射 --><association property="idCard" javaType="IDCard"><id property="cardId" column="card_id"/><result property="cardNumber" column="card_number"/></association>
</resultMap><!-- 
查询用户及其身份证信息
功能:从users和id_card表中查询用户及身份证数据,并通过UserWithIDCardMap结果映射转换为Java对象
说明:1. id="getUserWithIDCard":标识这个查询操作的唯一名称。2. resultMap="UserWithIDCardMap":指定使用UserWithIDCardMap结果映射来处理查询结果。3. SELECT u.user_id, u.user_name, c.card_id, c.card_number FROM users u LEFT JOIN id_card c ON u.user_id = c.user_id:- 查询users表和id_card表的联合数据。- LEFT JOIN将users表和id_card表连接,连接条件为用户ID(u.user_id = c.user_id)。- 查询结果将包含用户的基本信息和其关联的身份证信息。
用法:在Mapper接口中定义对应的方法,例如:User getUserWithIDCard();返回一个包含用户及其身份证信息的User对象。-->
<select id="getUserWithIDCard" resultMap="UserWithIDCardMap">SELECT u.user_id, u.user_name, c.card_id, c.card_numberFROM users uLEFT JOIN id_card c ON u.user_id = c.user_id
</select>

2. 一对多关联 <collection>

场景:用户(User)与订单(Order)一对多关联。
Java 对象

public class User {private Integer userId;private String userName;private List<Order> orders; // 一对多集合
}

映射配置

<!-- 
用户与订单的结果映射
功能:将用户信息及其关联的订单信息映射到User对象
说明:1. id="UserWithOrdersMap":标识这个结果映射的唯一名称。2. type="User":指定目标Java对象类型为User。3. <id property="userId" column="user_id">:定义User对象的userId属性与数据库表的user_id列对应,作为主键。4. <result property="userName" column="user_name">:定义User对象的userName属性与数据库表的user_name列对应。5. <collection property="orders" ofType="Order">- property="orders":User对象中的orders属性,表示用户的订单集合。- ofType="Order":指定集合中元素的类型为Order。- <id property="orderId" column="order_id">:定义Order对象的orderId属性与数据库表的order_id列对应,作为主键。- <result property="orderNo" column="order_no">:定义Order对象的orderNo属性与数据库表的order_no列对应。- <result property="amount" column="amount">:定义Order对象的amount属性与数据库表的amount列对应。- 通过这个集合映射,可以将用户的订单信息作为嵌套集合封装到User对象中。-->
<resultMap id="UserWithOrdersMap" type="User"><id property="userId" column="user_id"/><result property="userName" column="user_name"/><!-- 集合映射 --><collection property="orders" ofType="Order"><id property="orderId" column="order_id"/><result property="orderNo" column="order_no"/><result property="amount" column="amount"/></collection>
</resultMap><!-- 
查询用户及其订单信息
功能:从users和orders表中查询用户及订单数据,并通过UserWithOrdersMap结果映射转换为Java对象
说明:1. id="getUserWithOrders":标识这个查询操作的唯一名称。2. resultMap="UserWithOrdersMap":指定使用UserWithOrdersMap结果映射来处理查询结果。3. SELECT u.user_id, u.user_name, o.order_id, o.order_no, o.amount FROM users u LEFT JOIN orders o ON u.user_id = o.user_id:- 查询users表和orders表的联合数据。- LEFT JOIN将users表和orders表连接,连接条件为用户ID(u.user_id = o.user_id)。- 查询结果将包含用户的基本信息和其关联的订单信息。
用法:在Mapper接口中定义对应的方法,例如:User getUserWithOrders();返回一个包含用户及其订单信息的User对象。-->
<select id="getUserWithOrders" resultMap="UserWithOrdersMap">SELECT u.user_id, u.user_name,o.order_id, o.order_no, o.amountFROM users uLEFT JOIN orders o ON u.user_id = o.user_id
</select>

四、高级用法

1. 继承映射 (extends)

复用已有的 resultMap,避免重复配置。

<!-- 
基础用户结果映射
功能:定义了一个基础的结果映射,包含用户的基本字段(user_id 和 user_name)
说明:1. id="BaseUserMap":标识这个结果映射的唯一名称。2. type="User":指定目标Java对象类型为User。3. <id property="userId" column="user_id">:定义User对象的userId属性与数据库表的user_id列对应,作为主键。4. <result property="userName" column="user_name">:定义User对象的userName属性与数据库表的user_name列对应。5. 这个基础映射可以被其他映射继承和扩展,避免重复定义公共字段。-->
<resultMap id="BaseUserMap" type="User"><id property="userId" column="user_id"/><result property="userName" column="user_name"/>
</resultMap><!-- 
扩展基础用户结果映射,添加新字段
功能:在基础用户映射的基础上,添加一个新的字段(email)
说明:1. id="ExtendedUserMap":标识这个结果映射的唯一名称。2. extends="BaseUserMap":表示继承BaseUserMap中的所有字段和配置。3. type="User":指定目标Java对象类型为User。4. <result property="email" column="email">:新增字段,定义User对象的email属性与数据库表的email列对应。5. 通过继承基础映射,可以避免重复定义公共字段,简化配置。-->
<resultMap id="ExtendedUserMap" extends="BaseUserMap" type="User"><result property="email" column="email"/>
</resultMap>

2. 构造函数映射 <constructor>

通过构造方法注入字段(适合不可变对象)。
Java 对象

public class User {private final Integer userId;private final String userName;public User(Integer userId, String userName) {this.userId = userId;this.userName = userName;}
}

映射配置

<!-- 
用户结果映射(基于构造函数)
功能:将数据库查询结果通过构造函数映射到User对象
说明:1. id="UserConstructorMap":标识这个结果映射的唯一名称。2. type="User":指定目标Java对象类型为User。3. <constructor>:表示将通过User类的构造函数来初始化对象。4. <arg column="user_id" javaType="int">:- 定义构造函数的第一个参数,对应数据库列user_id,Java类型为int。5. <arg column="user_name" javaType="String">:- 定义构造函数的第二个参数,对应数据库列user_name,Java类型为String。6. 这个结果映射要求User类有一个接受两个参数(int user_id, String user_name)的构造函数。
用法:在需要使用构造函数映射的场景下,通过这个resultMap将查询结果转换为User对象。-->
<resultMap id="UserConstructorMap" type="User"><constructor><arg column="user_id" javaType="int"/><arg column="user_name" javaType="String"/></constructor>
</resultMap>

3. 嵌套查询(分步查询)

解决关联查询的 N+1 性能问题,通过分步加载数据。

<!-- 
用户与订单的延迟加载映射 先查用户,再通过 user_id 查订单
功能:定义了一个结果映射,用于将用户信息和其关联的订单信息进行映射。在查询用户时,不会立即加载订单信息,而是通过延迟加载的方式在需要时再加载。
说明:1. id="UserWithLazyOrdersMap":标识这个结果映射的唯一名称。2. type="User":指定目标Java对象类型为User。3. <id property="userId" column="user_id">:定义User对象的userId属性与数据库表的user_id列对应,作为主键。4. <result property="userName" column="user_name">:定义User对象的userName属性与数据库表的user_name列对应。5. <collection property="orders" ofType="Order" select="com.example.OrderMapper.getOrdersByUserId" column="user_id">- property="orders":User对象中的orders属性,表示用户关联的订单集合。- ofType="Order":指定集合中元素的类型为Order。- select="com.example.OrderMapper.getOrdersByUserId":指定一个单独的SQL查询语句,用于根据用户ID查询订单信息。- column="user_id":将查询结果中的user_id列作为参数传递给子查询。-->
<resultMap id="UserWithLazyOrdersMap" type="User"><id property="userId" column="user_id"/><result property="userName" column="user_name"/><collection property="orders" ofType="Order"select="com.example.OrderMapper.getOrdersByUserId"column="user_id"/> <!-- 将 user_id 作为参数传递给子查询 -->
</resultMap><!-- 
查询用户信息(延迟加载订单)
功能:根据用户ID查询用户的基本信息,并通过延迟加载的方式获取其关联的订单信息。
说明:1. id="getUser":标识这个查询操作的唯一名称。2. resultMap="UserWithLazyOrdersMap":指定使用UserWithLazyOrdersMap结果映射来处理查询结果。3. SELECT user_id, user_name FROM users WHERE user_id = #{id}:- 查询users表中的user_id和user_name列。- WHERE user_id = #{id}:根据传入的用户ID进行查询。
用法:在Mapper接口中定义对应的方法,例如:User getUser(int id);返回一个包含用户基本信息的User对象,其orders属性在需要时才会加载。-->
<select id="getUser" resultMap="UserWithLazyOrdersMap">SELECT user_id, user_name FROM users WHERE user_id = #{id}
</select>

OrderMapper.xml

<!-- 
根据用户ID查询订单信息
功能:从orders表中查询指定用户的所有订单
参数:userId(用户ID)
返回:Order对象的列表,包含该用户的所有订单信息
说明:1. id="getOrdersByUserId":标识这个查询操作的唯一名称。2. resultType="Order":指定查询结果的类型为Order对象。3. SELECT * FROM orders WHERE user_id = #{userId}:- 查询orders表中所有列的数据。- WHERE user_id = #{userId}:条件是订单的user_id等于传入的userId参数。
用法:在Mapper接口中定义对应的方法,例如:List<Order> getOrdersByUserId(int userId);调用时传入用户ID,返回该用户的所有订单信息。-->
<select id="getOrdersByUserId" resultType="Order">SELECT * FROM orders WHERE user_id = #{userId}
</select>

在这里插入图片描述


五、常见问题与最佳实践

  1. 主键必须配置<id> 影响缓存机制,未配置可能导致性能下降。
  2. 避免过度嵌套:复杂关联建议使用分步查询(嵌套查询)减少单次 SQL 复杂度。
  3. 自动映射的取舍:简单场景可开启 autoMapping,复杂字段仍需显式配置。
  4. 性能优化:一对多关联使用懒加载(fetchType="lazy"),按需加载数据。

六、总结

拓展阅读:MyBatis映射文件常用元素详解与示例
官方文档:MyBatis | XML 映射文件
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/895476.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

WIN11上使用GraalVM打包springboot3项目为本地可执行文件exe

耐心肝才能成功 概念步骤概要详细步骤一. GraalVM 17二. 安装Visual Studio 2022三. 创建springboot四. IDEA最新版或者eclipse2025调试项目五. 打包exe 概念 springboot3生成的jar编译成windows本地C文件&#xff0c;不再依赖JVM运行 WINDOW编译较为复杂&#xff0c;限制条件…

【git-hub项目:YOLOs-CPP】本地实现01:项目构建

目录 写在前面 项目介绍 最新发布说明 Segmentation示例 功能特点 依赖项 安装 克隆代码仓库 配置 构建项目 写在前面 前面刚刚实现的系列文章: 【Windows/C++/yolo开发部署01】 【Windows/C++/yolo开发部署02】 【Windows/C++/yolo开发部署03】 【Windows/C++/yolo…

超越 DeepSeek V3 -->【Qwen2.5-Max】

&#x1f525; 先说明&#xff0c;不是广子&#xff0c;不是广子&#xff01;&#xff01;&#xff01;单纯分享这个工具给大家&#xff0c;毕竟最近使用 DeepSeek 太容易崩了&#xff0c;每天深度思考一次之后就开始转圈圈用不了&#xff0c;然后就找到了这个工具使用 一、前言…

python自动化测试之Pytest框架之YAML详解以及Parametrize数据驱动!

一、YAML详解 YAML是一种数据类型&#xff0c;它能够和JSON数据相互转化&#xff0c;它本身也是有很多数据类型可以满足我们接口 的参数类型&#xff0c;扩展名可以是.yml或.yaml 作用&#xff1a; 1.全局配置文件 基础路径&#xff0c;数据库信息&#xff0c;账号信息&…

CentOS 7操作系统部署KVM软件和创建虚拟机

CentOS 7.9操作系统部署KVM软件和配置指南&#xff0c;包括如何创建一个虚拟机。 步骤 1: 检查硬件支持 首先&#xff0c;确认您的CPU支持虚拟化技术&#xff0c;并且已在BIOS中启用&#xff1a; egrep -c (vmx|svm) /proc/cpuinfo 如果输出大于0&#xff0c;则表示支持虚拟…

日本 万叶假名

万叶假名&#xff08;まんようがな&#xff0c;Manyōgana&#xff09;是一种早期的日语书写系统&#xff0c;主要用于《万叶集》等古代文献中。它的特点是完全使用汉字来表示日语的音&#xff0c;不考虑汉字的原意。可以将其视为平假名和片假名的前身。 记住是唐代的发音不是…

【鸿蒙HarmonyOS Next实战开发】实现组件动态创建和卸载-优化性能

一、简介 为了解决页面和组件加载缓慢的问题&#xff0c;ArkUI框架引入了动态操作功能&#xff0c;支持组件的预创建&#xff0c;并允许应用在运行时根据实际需求动态加载和渲染组件。 这些动态操作包括动态创建组件&#xff08;即动态添加组件&#xff09;和动态卸载组件&am…

MongoDB 7 分片副本集升级方案详解(上)

#作者&#xff1a;任少近 文章目录 前言&#xff1a;Mongodb版本升级升级步骤环境1.1环境准备1.2standalone升级1.3分片、副本集升级 前言&#xff1a;Mongodb版本升级 在开始升级之前&#xff0c;请参阅 MongoDB下个版本中的兼容性变更文档&#xff0c;以确保您的应用程序和…

AI前端开发:跨领域合作的新引擎

随着人工智能技术的飞速发展&#xff0c;AI代码生成器等工具的出现正深刻地改变着软件开发的模式。 AI前端开发的兴起&#xff0c;不仅提高了开发效率&#xff0c;更重要的是促进了跨领域合作&#xff0c;让数据科学家、UI/UX设计师和前端工程师能够更紧密地协同工作&#xff0…

DeepSeek 助力 Vue 开发:打造丝滑的返回顶部按钮(Back to Top)

前言&#xff1a;哈喽&#xff0c;大家好&#xff0c;今天给大家分享一篇文章&#xff01;并提供具体代码帮助大家深入理解&#xff0c;彻底掌握&#xff01;创作不易&#xff0c;如果能帮助到大家或者给大家一些灵感和启发&#xff0c;欢迎收藏关注哦 &#x1f495; 目录 Deep…

Java练习(20)

ps:练习来自力扣 给你一个 非空 整数数组 nums &#xff0c;除了某个元素只出现一次以外&#xff0c;其余每个元素均出现两次。找出那个只出现了一次的元素。 你必须设计并实现线性时间复杂度的算法来解决此问题&#xff0c;且该算法只使用常量额外空间。 class Solution {pu…

Tetragon:一款基于eBPF的运行时环境安全监控工具

关于Tetragon Tetragon是一款基于eBPF的运行时环境安全监控工具&#xff0c;该工具可以帮助广大研究人员检测并应对安全重大事件&#xff0c;例如流程执行事件、系统调用活动、I/O活动&#xff08;包括网络和文件访问等&#xff09;。 在 Kubernetes 环境中使用时&#xff0c;…

Qt多线程技术【线程池】:QRunnable 和 QThreadPool

在现代软件开发中&#xff0c;尤其是在处理大量并发任务时&#xff0c;线程池技术是一种高效的解决方案。线程池不仅能提高程序的性能&#xff0c;还能有效管理线程的生命周期&#xff0c;避免频繁的线程创建和销毁所带来的性能损失。本文将以Qt中的 QThreadPool 和 QRunnable …

218.子结构判断

class Solution {/*** 判断树 B 是否是树 A 的子结构* param A 树 A 的根节点* param B 树 B 的根节点* return 如果 B 是 A 的子结构&#xff0c;返回 true&#xff1b;否则返回 false*/public boolean isSubStructure(TreeNode A, TreeNode B) {// 如果树 B 为空&#xff0c;…

Navicat导入海量Excel数据到数据库(简易介绍)

目录 前言正文 前言 此处主要作为科普帖进行记录 原先Java处理海量数据的导入时&#xff0c;由于接口超时&#xff0c;数据处理不过来&#xff0c;后续转为Navicat Navicat 是一款功能强大的数据库管理工具&#xff0c;支持多种数据库系统&#xff08;如 MySQL、PostgreSQL、…

文化财经t8优质短线期货交易量化模型源码

// 参数设置 BOLL_PERIOD : 20; // 布林带周期 RSI_PERIOD : 14; // RSI 周期 OVERSOLD : 30; // 超卖线 OVERBOUGHT : 70; // 超买线 // 计算布林带 MID : MA(CLOSE, BOLL_PERIOD); UPPER : MID 2 * STD(CLOSE, BOLL_PERIOD); LOWER : MID - 2 * STD(CLOSE,…

[AI]Mac本地部署Deepseek R1模型 — — 保姆级教程

[AI]Mac本地部署DeepSeek R1模型 — — 保姆级教程 DeepSeek R1是中国AI初创公司深度求索&#xff08;DeepSeek&#xff09;推出大模型DeepSeek-R1。 作为一款开源模型&#xff0c;R1在数学、代码、自然语言推理等任务上的性能能够比肩OpenAI o1模型正式版&#xff0c;并采用MI…

【UE5】PeerStream像素流部署

视频教程 https://www.bilibili.com/video/BV1GhiuecEpK?spm_id_from333.788.videopod.sections&vd_source02dd8acc3a83a728e375ff61f1ebe725步骤 下载PeerStream代码 代码结构和项目如图 github地址:https://github.com/inveta/PeerStreamEnterprise下载node node 对应…

老牌系统工具箱,现在还能打!

今天给大家分享一款超实用的电脑软硬件检测工具&#xff0c;虽然它是一款比较“资深”的软件&#xff0c;但依然非常好用&#xff0c;完全能满足我们的日常需求。 电脑软硬件维护检测工具 功能强大易用 这款软件非常贴心&#xff0c;完全不需要安装&#xff0c;直接打开就能用…

java商城解决方案

数字化时代&#xff0c;电子商务已成为企业拓展市场的重要渠道。对于想要建立在线商店的企业来说&#xff0c;选择正确的技术堆栈至关重要。 Java作为一种成熟且广泛使用的编程语言&#xff0c;为构建购物中心提供了强大的功能和灵活性。 商城Java源码&#xff1a;商城开发的核…