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,则将它们作为查询条件。

相关文章
|
SQL Java 数据库连接
【YashanDB知识库】解决mybatis的mapper文件sql语句结尾加分号";"报错
【YashanDB知识库】解决mybatis的mapper文件sql语句结尾加分号";"报错
|
7月前
|
SQL Java 数据库连接
MyBatis 的映射关系
MyBatis 核心功能之一是映射关系,支持一对一、一对多和多对多三种 ORM 映射。通过实体类与配置文件结合,开发者可灵活实现数据关联,提升数据库操作效率。
399 4
|
XML Java 数据库连接
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——基于 xml 的整合
本教程介绍了基于XML的MyBatis整合方式。首先在`application.yml`中配置XML路径,如`classpath:mapper/*.xml`,然后创建`UserMapper.xml`文件定义SQL映射,包括`resultMap`和查询语句。通过设置`namespace`关联Mapper接口,实现如`getUserByName`的方法。Controller层调用Service完成测试,访问`/getUserByName/{name}`即可返回用户信息。为简化Mapper扫描,推荐在Spring Boot启动类用`@MapperScan`注解指定包路径避免逐个添加`@Mapper`
841 0
|
11月前
|
Android开发 开发者
Android自定义View之不得不知道的文件attrs.xml(自定义属性)
本文详细介绍了如何通过自定义 `attrs.xml` 文件实现 Android 自定义 View 的属性配置。以一个包含 TextView 和 ImageView 的 DemoView 为例,讲解了如何使用自定义属性动态改变文字内容和控制图片显示隐藏。同时,通过设置布尔值和点击事件,实现了图片状态的切换功能。代码中展示了如何在构造函数中解析自定义属性,并通过方法 `setSetting0n` 和 `setbackeguang` 实现功能逻辑的优化与封装。此示例帮助开发者更好地理解自定义 View 的开发流程与 attrs.xml 的实际应用。
320 2
Android自定义View之不得不知道的文件attrs.xml(自定义属性)
|
11月前
|
SQL XML Java
菜鸟之路Day35一一Mybatis之XML映射与动态SQL
本文介绍了MyBatis框架中XML映射与动态SQL的使用方法,作者通过实例详细解析了XML映射文件的配置规范,包括namespace、id和resultType的设置。文章还对比了注解与XML映射的优缺点,强调复杂SQL更适合XML方式。在动态SQL部分,重点讲解了`&lt;if&gt;`、`&lt;where&gt;`、`&lt;set&gt;`、`&lt;foreach&gt;`等标签的应用场景,如条件查询、动态更新和批量删除,并通过代码示例展示了其灵活性与实用性。最后,通过`&lt;sql&gt;`和`&lt;include&gt;`实现代码复用,优化维护效率。
1057 5
|
XML Java 数据库连接
二、搭建MyBatis采用xml方式,验证CRUD(增删改查操作)
二、搭建MyBatis采用xml方式,验证CRUD(增删改查操作)
401 21
|
SQL Java 数据库连接
【YashanDB 知识库】解决 mybatis 的 mapper 文件 sql 语句结尾加分号";"报错
【YashanDB 知识库】解决 mybatis 的 mapper 文件 sql 语句结尾加分号";"报错
|
SQL XML Java
七、MyBatis自定义映射resultMap
七、MyBatis自定义映射resultMap
394 6
|
XML Java 数据库连接
Mybatis映射关系
简介:本文介绍了MyBatis框架中四种常见的关系映射方式,包括一对一、一对多、多对一及多对多。一对一通过简单属性映射实现;一对多通过在主对象中添加集合属性并使用`&lt;collection&gt;`标签映射子对象集合;多对一则利用`&lt;association&gt;`标签在主对象中映射单个子对象;多对多需引入第三方类,分别在两个主对象中添加对方的集合属性,并通过`&lt;collection&gt;`标签实现映射。
275 32
|
Java 数据库连接 mybatis
MyBatis篇-映射关系(1-1 1-n n-n)
本文介绍了MyBatis中四种常见关系映射的配置方法,包括一对一、一对多、多对一和多对多。**一对一**通过`resultMap`实现属性与字段的映射;**一对多**以用户-角色为例,使用`&lt;collection&gt;`标签关联集合数据;**多对一**以作者-博客为例,利用`&lt;association&gt;`实现关联;**多对多**则通过引入第三方类(如UserForDept)分别在User和Dept类中添加集合属性,并配置对应的`&lt;collection&gt;`标签完成映射。这些方法解决了复杂数据关系的处理问题,提升了开发效率。
下一篇
开通oss服务