MyBatis XML 映射文件

简介: MyBatis XML 映射文件

XML 映射文件的基本结构


MyBatis 的 XML 映射文件包含以下几个部分:


  • mapper 元素:定义了 XML 映射文件的根元素,其中包含了命名空间和 SQL 语句等信息。

  • selectinsertupdatedelete 元素:分别用于定义查询、插入、更新、删除操作的 SQL 语句。

  • resultMap 元素:用于定义结果集的映射关系。

  • parameterMap 元素:用于定义参数的映射关系。

  • sql 元素:用于定义 SQL 片段,可以在其他 SQL 语句中引用。

以下是一个简单的 XML 映射文件示例:

<!-- UserMapper.xml -->
<mapper namespace="com.example.mapper.UserMapper">
  <select id="getUserById" parameterType="int" resultType="com.example.model.User">
    SELECT * FROM user WHERE id = #{id}
  </select>
</mapper>

在上述代码中,我们定义了一个 UserMapper 的 XML 映射文件,并在其中定义了一个名为 getUserById 的查询操作。该操作接收一个 int 类型的参数 id,返回一个 com.example.model.User 类型的结果集。


XML 映射文件的语法规则


在 XML 映射文件中,我们需要遵循以下语法规则:


  • 所有 XML 元素必须有一个结束标签。

  • 属性值必须使用引号括起来。

  • XML 元素名称和属性名称都是大小写敏感的。

  • XML 注释可以使用 <!-- --> 标记。

以下是一个 XML 映射文件的完整示例:

<!-- UserMapper.xml -->
<mapper namespace="com.example.mapper.UserMapper">
  <select id="getUserById" parameterType="int" resultType="com.example.model.User">
    SELECT * FROM user WHERE id = #{id}
  </select>
  <insert id="insertUser" parameterType="com.example.model.User">
    INSERT INTO user (username, password) VALUES (#{username}, #{password})
  </insert>
  <update id="updateUser" parameterType="com.example.model.User">
    UPDATE user SET password = #{password} WHERE id = #{id}
  </update>
  <delete id="deleteUser" parameterType="int">
    DELETE FROM user WHERE id = #{id}
  </delete>
  <resultMap id="userMap" type="com.example.model.User">
    <id property="id" column="id" />
    <result property="username" column="username" />
    <result property="password" column="password" />
  </resultMap>
</mapper>

在上述代码中,我们定义了一个 UserMapper 的 XML 映射文件,并在其中定义了查询、插入、更新、删除操作以及结果映射关系。


XML 映射文件的常见用法


在 XML 映射文件中,我们可以使用以下常见用法:


  • 使用 parameterType 属性来指定参数类型。

  • 使用 resultType 属性来指定结果类型。

  • 使用 #{} 占位符来表示参数。

  • 使用 <if><where><foreach> 等元素来动态生成 SQL 语句。

  • 使用 <selectKey> 元素来获取自动生成的主键值。

以下是一个使用 <if> 元素的示例:

<!-- UserMapper.xml -->
<mapper namespace="com.example.mapper.UserMapper">
  <select id="getUserByUsernameAndPassword" parameterType="com.example.model.User" resultType="com.example.model.User">
    SELECT * FROM user WHERE 1 = 1
    <if test="username != null">
      AND username = #{username}
    </if>
    <if test="password != null">
      AND password = #{password}
    </if>
  </select>
</mapper>

在上述代码中,我们定义了一个名为 getUserByUsernameAndPassword 的查询操作,并使用 <if> 元素来动态生成 SQL 语句。如果 usernamepassword 不为 null,则将它们作为查询条件。

相关文章
|
1月前
|
XML Java 数据格式
Spring5入门到实战------7、IOC容器-Bean管理XML方式(外部属性文件)
这篇文章是Spring5框架的实战教程,主要介绍了如何在Spring的IOC容器中通过XML配置方式使用外部属性文件来管理Bean,特别是数据库连接池的配置。文章详细讲解了创建属性文件、引入属性文件到Spring配置、以及如何使用属性占位符来引用属性文件中的值。
Spring5入门到实战------7、IOC容器-Bean管理XML方式(外部属性文件)
|
20天前
|
SQL XML Java
mybatis :sqlmapconfig.xml配置 ++++Mapper XML 文件(sql/insert/delete/update/select)(增删改查)用法
当然,这些仅是MyBatis功能的初步介绍。MyBatis还提供了高级特性,如动态SQL、类型处理器、插件等,可以进一步提供对数据库交互的强大支持和灵活性。希望上述内容对您理解MyBatis的基本操作有所帮助。在实际使用中,您可能还需要根据具体的业务要求调整和优化SQL语句和配置。
26 1
|
2月前
|
SQL Java 数据库连接
idea中配置mybatis 映射文件模版及 mybatis plus 自定义sql
idea中配置mybatis 映射文件模版及 mybatis plus 自定义sql
56 3
|
1月前
|
XML 监控 数据格式
ROS 2 - Python、XML 和 YAML 编写 Launch 文件
ROS 2 - Python、XML 和 YAML 编写 Launch 文件
153 0
|
1月前
|
SQL Java 数据库连接
MyBatis Mapper.XML 标签使用说明
MyBatis Mapper.XML 标签使用说明
25 0
若依修改,集成mybatisplus报错,若依集成mybatisplus,总是找不到映射是怎么回事只要是用mp的方法就找报,改成mybatisPlus配置一定要改
若依修改,集成mybatisplus报错,若依集成mybatisplus,总是找不到映射是怎么回事只要是用mp的方法就找报,改成mybatisPlus配置一定要改
|
2月前
|
XML Java 数据格式
支付系统----微信支付20---创建案例项目--集成Mybatis-plus的补充,target下只有接口的编译文件,xml文件了,添加日志的写法
支付系统----微信支付20---创建案例项目--集成Mybatis-plus的补充,target下只有接口的编译文件,xml文件了,添加日志的写法
|
6天前
|
缓存 前端开发 Java
【Java面试题汇总】Spring,SpringBoot,SpringMVC,Mybatis,JavaWeb篇(2023版)
Soring Boot的起步依赖、启动流程、自动装配、常用的注解、Spring MVC的执行流程、对MVC的理解、RestFull风格、为什么service层要写接口、MyBatis的缓存机制、$和#有什么区别、resultType和resultMap区别、cookie和session的区别是什么?session的工作原理
【Java面试题汇总】Spring,SpringBoot,SpringMVC,Mybatis,JavaWeb篇(2023版)
|
22天前
|
Java 数据库连接 测试技术
SpringBoot 3.3.2 + ShardingSphere 5.5 + Mybatis-plus:轻松搞定数据加解密,支持字段级!
【8月更文挑战第30天】在数据驱动的时代,数据的安全性显得尤为重要。特别是在涉及用户隐私或敏感信息的应用中,如何确保数据在存储和传输过程中的安全性成为了开发者必须面对的问题。今天,我们将围绕SpringBoot 3.3.2、ShardingSphere 5.5以及Mybatis-plus的组合,探讨如何轻松实现数据的字段级加解密,为数据安全保驾护航。
73 1
|
1月前
|
Web App开发 前端开发 关系型数据库
基于SpringBoot+Vue+Redis+Mybatis的商城购物系统 【系统实现+系统源码+答辩PPT】
这篇文章介绍了一个基于SpringBoot+Vue+Redis+Mybatis技术栈开发的商城购物系统,包括系统功能、页面展示、前后端项目结构和核心代码,以及如何获取系统源码和答辩PPT的方法。