MyBatis XML映射文件编写【后端 18】

news/2024/11/14 20:27:02/
xmlns="http://www.w3.org/2000/svg" style="display: none;">

MyBatis XML映射文件编写

请添加图片描述

MyBatis 是一个优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解用于配置和原始映射,将接口和 Java 的 POJOs (Plain Old Java Objects, 普通的 Java 对象)映射成数据库中的记录。

在 MyBatis 中,XML 映射文件是非常关键的部分,它定义了如何将 Java 对象映射到 SQL 语句以及如何将 SQL 查询结果映射回 Java 对象。下面,我们将详细介绍如何编写 MyBatis 的 XML 映射文件。

1. XML 映射文件的基本结构

每个 MyBatis 的映射文件都包含了一个 <mapper> 元素作为根元素。在 <mapper> 元素内部,你可以定义多种映射语句,如 <select><insert><update><delete>

xml"><?xml version="1.0" encoding="UTF-8" ?>  
<!DOCTYPE mapper  PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"  "http://mybatis.org/dtd/mybatis-3-mapper.dtd">  
<mapper namespace="com.example.mapper.UserMapper">  <!-- SQL 映射语句将在这里定义 -->  </mapper>
  • namespace:命名空间,它是绑定 MyBatis 接口的全路径名,用于唯一标识 mapper。
2. SQL 映射语句
2.1 <select>

用于查询操作。你可以使用 #{} 来进行参数替换,防止 SQL 注入。

xml"><select id="selectUserById" parameterType="int" resultType="com.example.domain.User">  SELECT * FROM users WHERE id = #{id}  
</select>
  • id:唯一标识符,与 Mapper 接口中的方法名对应。
  • parameterType:输入参数的类型。
  • resultType:SQL 查询返回的结果类型,即 Java 对象的全路径名。
2.2 <insert><update><delete>

这些标签分别用于插入、更新和删除操作。对于修改数据库的操作,MyBatis 支持使用 <selectKey> 来获取自动生成的主键。

xml"><insert id="insertUser" parameterType="com.example.domain.User">  <selectKey keyProperty="id" resultType="int" order="AFTER">  SELECT LAST_INSERT_ID()  </selectKey>  INSERT INTO users (name, email) VALUES (#{name}, #{email})  
</insert>
  • keyProperty:指定 Java 对象的哪个属性用于接收生成的主键值。
  • order:指定 <selectKey> 相对于插入语句的执行顺序,BEFOREAFTER
3. 映射复杂结果

对于复杂的查询,你可能需要将结果映射到多个 Java 对象或者映射到 Java 对象的集合中。MyBatis 提供了 <resultMap> 元素来支持复杂的映射。

xml"><resultMap id="userResultMap" type="com.example.domain.User">  <id property="id" column="user_id" />  <result property="username" column="user_name" />  <result property="email" column="email_address" />  <!-- 更多映射 -->  
</resultMap>  <select id="selectUsers" resultMap="userResultMap">  SELECT user_id, user_name, email_address FROM users  
</select>
  • :用于映射主键字段。
  • :用于映射非主键字段。
4. 注意事项
  • 确保 XML 文件的命名空间和路径与 Mapper 接口的全路径名一致。
  • <mapper> 标签内,避免使用 MyBatis 保留的关键字。
  • 仔细检查 SQL 语句中的参数替换,确保没有 SQL 注入的风险。
  • 使用 <resultMap> 可以更灵活地控制复杂对象的映射关系。

通过上面的介绍,你应该对 MyBatis 的 XML 映射文件编写有了基本的了解。在实际开发中,根据具体需求编写相应的 SQL 映射语句,将大大提高数据访问层的开发效率和灵活性。


http://www.ppmy.cn/news/1529157.html

相关文章

Centos7.9 使用 Kubeadm 自动化部署 K8S 集群(一个脚本)

文章目录 一、环境准备1、硬件准备&#xff08;虚拟主机&#xff09;2、操作系统版本3、硬件配置4、网络 二、注意点1、主机命名格式2、网络插件 flannel 镜像拉取2.1、主机生成公私钥2.2、为啥有 Github 还用 Gitee2.3、将主机公钥添加到 Gitee2.3.1、复制主机上的公钥2.3.2、…

2024年中国科技核心期刊目录(自然科学卷)科技统计源核心(续)

2024年中国科技核心期刊目录 &#xff08;自然科学卷&#xff09; 序号 期刊代码 期刊名称 1001 G855 临床消化病杂志 1002 Q909…

Vue3新组件transition(动画过渡)

transition组件&#xff1a;控制V-if与V-show的显示与隐藏动画 1.基本使用 <template><div><button click"falg !falg">切换</button><transition name"fade" :enter-to-class"etc"><div v-if"falg&quo…

shopro前端 短信登录只显示模板不能正常切换

删掉 换成下面的代码 // 打开授权弹框 export function showAuthModal(type smsLogin) {const modal $store(modal);setTimeout(() > {modal.$patch((state) > {state.auth type;});}, 100); }

tensorflow算子调用示例(MINIST)

tensorflow算子调用示例(MINIST) 本文以MINIST为例&#xff0c;阐述在模型训练时&#xff0c;tensorflow框架每个算子具体调用kernel的过程。 1. 数据准备和输入 在 MNIST 示例中&#xff0c;首先加载数据并进行预处理&#xff0c;生成用于训练和测试的数据集。这个步骤本身…

Python知识点:如何使用Python进行智能合约开发(Solidity、Web3.py)

开篇&#xff0c;先说一个好消息&#xff0c;截止到2025年1月1日前&#xff0c;翻到文末找到我&#xff0c;赠送定制版的开题报告和任务书&#xff0c;先到先得&#xff01;过期不候&#xff01; 要使用Python进行智能合约开发&#xff0c;你需要了解Solidity语言和Web3.py库。…

数据湖 Data Lake-概述

Data Lake 1. 数据湖的定义 数据湖是一种存储系统&#xff0c;用于集中存储大量的原始数据&#xff0c;可以按数据本来的原始格式进行存储&#xff0c;用户可以在需要时提取和分析这些数据。 A data lake is a centralized repository designed to hold vast volumes of data …

Kubernetes从零到精通(11-CNI网络插件)

Kubernetes网络模型 Kubernetes的网络模型&#xff08;Kubernetes Networking Model&#xff09;旨在提供跨所有节点、Pod和服务的统一网络连接。它的核心理念是通过统一的网络通信规则&#xff0c;保证集群中的所有组件能够顺畅地相互通信。Kubernetes网络模型主要有以下几个关…