MyBatis映射文件深入--动态sql

简介: MyBatis映射文件深入--动态sql

前言


前面我们学习了MaBatis的入门使用,可以知道,MaBatis能够减少我们的后端代码的重复性,并且我们可以通过插件直接生成简单的MaBatis映射文件,如果没有看过上一篇的小伙伴可以在我的专栏看看,但是我们也发现了一个问题,这样的sql太简单了,无法满足我们日常企业的开发要求,所以今天就来讲一下使用动态sql来玩完成我们的进阶数据操作


动态sql概述


动态SQL的概念是基于条件判断和循环来动态生成SQL语句。通过使用MyBatis的动态SQL功能,你可以根据不同的条件来拼接SQL语句,从而实现灵活的查询。


动态sql的使用


if

类似于java种的if语句

  <sql id="Base_Column_List" >
    id, name
  </sql>
  <select id="selectByPrimaryKey" resultMap="BaseResultMap" parameterType="java.lang.Integer" >
    select
    <include refid="Base_Column_List" />
    from dept
    where id = #{id,jdbcType=INTEGER}
  </select>

其中sql元素类似于封装好的语句,通过include元素进行引入,减少了代码的重复性


foreach

循环执行sql的拼接操作,例如:SELECT * FROM USER WHERE id IN (1,2,5)。

<select id="findByIds" parameterType="list" resultType="user">
select * from User
<where>
<foreach collection="array" open="id in(" close=")" item="id" separator=",">
#{id}
</foreach>
</where>
</select>

这样的操作往往执行在购物车的批量删除功能,需要从前台通过多个参数进行操作


foreach标签的属性含义如下:


  • collection:代表要遍历的集合元素,注意编写时不要写#{}
  • open:代表语句的开始部分
  • close:代表结束部分
  • item:代表遍历集合的每个元素,生成的变量名
  • sperator:代表分隔符


<choose><when><otherwise>

<select id="selectBooks" resultMap="BaseResultMap" parameterType="com.ycxw.model.Book">
  SELECT * FROM t_mvc_book
  WHERE 1=1
  <choose>
    <when test="bid != null">
      AND bid= #{bid}
    </when>
    <when test="bname!= null">
      AND bname = #{bname}
    </when>
    <when test="price != null">
      AND price = #{price}
    </when>
    <otherwise>
      AND info= '哈哈哈'
    </otherwise>
  </choose>
</select>


在这个示例中,根据不同条件生成不同的SQL语句。如果第一个条件不成立就继续往下执行,直到when条件成立后就不会执行下面的判断了。如果没有传入任何参数,则默认生成 AND info= ' 哈哈哈' 条件


面试题


#和$的区别(面试题-重点)

在MyBatis的映射文件中,#$是两种不同的参数占位符,它们在使用方式和处理方式上有所区别。

  • #占位符:
  • 使用方式:#占位符用于替换参数值,通常在SQL语句中使用。例如:SELECT * FROM table WHERE id = #{id}。
  • 处理方式:#占位符会将参数值以安全的方式进行预编译,防止SQL注入攻击。MyBatis会将参数值转义并将其作为预编译参数传递给数据库。
  • $占位符:
  • 使用方式:$占位符用于替换参数值,通常在SQL语句中使用。例如:SELECT * FROM table WHERE id = ${id}。
  • 处理方式:$占位符会直接将参数值替换到SQL语句中,不进行预编译处理。这意味着参数值直接拼接到SQL语句中,可能存在安全风险,因此需要谨慎使用。


区别总结:

  • #占位符会将参数值进行预编译处理,安全性较高,适合用于传递参数值。
  • $占位符直接将参数值拼接到SQL语句中,不进行预编译处理,潜在安全风险较高,适合用于拼接动态的SQL片段


resulttype和resultmap的区别(面试题--重点)

在MyBatis映射文件中,resultTyperesultMap都是用于指定查询结果的映射方式,但它们有一些区别。


resultType

resultTyperesultType用于指定单个结果对象的类型。你可以直接指定一个Java类的全限定名作为resultType的值,MyBatis会自动创建该类型的对象,并将查询结果映射到该对象的属性上。例如:

<select id="getUser" resultType="com.example.User">
  SELECT * FROM user WHERE id = #{id}
</select>

上述示例中,查询结果将会映射到com.example.User类的对象上。


resultMap

resultMapresultMap用于自定义结果映射规则。你可以在映射文件中定义一个<resultMap>元素,指定查询结果与Java对象之间的映射关系。在<resultMap>中,你可以使用<result>元素来定义每个属性的映射规则。例如:

<resultMap id="userResultMap" type="com.example.User">
  <id property="id" column="id"/>
  <result property="name" column="name"/>
  <result property="age" column="age"/>
</resultMap>
<select id="getUser" resultMap="userResultMap">
  SELECT * FROM user WHERE id = #{id}
</select>


需要注意的是,其中的cloumn需要和数据库的字段名相同

  1. <id property="id" column="id"/>:这个<id>元素指定了主键的映射关系。property属性指定了映射到com.example.User类的哪个属性,column属性指定了查询结果中对应的列名。
  2. <result property="name" column="name"/>:这个<result>元素指定了普通属性的映射关系。property属性指定了映射到com.example.User类的哪个属性,column属性指定了查询结果中对应的列名。
  3. <result property="age" column="age"/>:这个<result>元素同样指定了普通属性的映射关系,映射到com.example.User类的age属性。

通过这样的映射配置,当执行查询操作时,MyBatis会将查询结果中的id列映射到com.example.User类的id属性,将name列映射到name属性,将age列映射到age属性。


我们还可以通过构造函数来进行映射

 <resultMap id="BaseResultMap" type="com.wenhao.oa.model.Dept" >
    <constructor >
      <idArg column="id" jdbcType="INTEGER" javaType="java.lang.Integer" />
      <arg column="name" jdbcType="VARCHAR" javaType="java.lang.String" />
    </constructor>
  </resultMap>


  1. <resultMap id="BaseResultMap" type="com.wenhao.oa.model.Dept">:这个<resultMap>元素定义了一个名为BaseResultMap的结果映射,它将查询结果映射到com.wenhao.oa.model.Dept类。type属性指定了映射的目标类型。
  2. <constructor>:这是<resultMap>的子元素,用于指定构造函数映射。在这个例子中,它表示将使用构造函数来创建com.wenhao.oa.model.Dept对象。
  3. <idArg column="id" jdbcType="INTEGER" javaType="java.lang.Integer" />:这是构造函数映射的子元素,用于指定构造函数的参数映射。在这个例子中,它表示将查询结果中的id列映射到构造函数的第一个参数,类型为java.lang.Integer。
  4. <arg column="name" jdbcType="VARCHAR" javaType="java.lang.String" />:这是构造函数映射的子元素,用于指定构造函数的参数映射。在这个例子中,它表示将查询结果中的name列映射到构造函数的第二个参数,类型为java.lang.String。

通过这样的映射配置,当执行查询操作时,MyBatis会将查询结果中的id列和name列的值分别传递给com.wenhao.oa.model.Dept类的构造函数,创建相应的对象。


总结来说,resultType适用于简单的结果映射,而resultMap适用于复杂的结果映射,可以自定义映射规则。根据具体的需求,你可以选择使用其中的一种或结合使用。

目录
相关文章
|
2月前
|
SQL Java 数据库连接
MyBatis 的映射关系
MyBatis 核心功能之一是映射关系,支持一对一、一对多和多对多三种 ORM 映射。通过实体类与配置文件结合,开发者可灵活实现数据关联,提升数据库操作效率。
248 4
|
8月前
|
SQL Java 数据库连接
【YashanDB知识库】解决mybatis的mapper文件sql语句结尾加分号";"报错
【YashanDB知识库】解决mybatis的mapper文件sql语句结尾加分号";"报错
|
6月前
|
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;`实现代码复用,优化维护效率。
557 5
|
8月前
|
SQL Java 数据库连接
【YashanDB 知识库】解决 mybatis 的 mapper 文件 sql 语句结尾加分号";"报错
【YashanDB 知识库】解决 mybatis 的 mapper 文件 sql 语句结尾加分号";"报错
|
8月前
|
SQL 缓存 Java
框架源码私享笔记(02)Mybatis核心框架原理 | 一条SQL透析核心组件功能特性
本文详细解构了MyBatis的工作机制,包括解析配置、创建连接、执行SQL、结果封装和关闭连接等步骤。文章还介绍了MyBatis的五大核心功能特性:支持动态SQL、缓存机制(一级和二级缓存)、插件扩展、延迟加载和SQL注解,帮助读者深入了解其高效灵活的设计理念。
|
8月前
|
SQL XML Java
七、MyBatis自定义映射resultMap
七、MyBatis自定义映射resultMap
233 6
|
8月前
|
Java 数据库连接 mybatis
MyBatis篇-映射关系(1-1 1-n n-n)
本文介绍了MyBatis中四种常见关系映射的配置方法,包括一对一、一对多、多对一和多对多。**一对一**通过`resultMap`实现属性与字段的映射;**一对多**以用户-角色为例,使用`&lt;collection&gt;`标签关联集合数据;**多对一**以作者-博客为例,利用`&lt;association&gt;`实现关联;**多对多**则通过引入第三方类(如UserForDept)分别在User和Dept类中添加集合属性,并配置对应的`&lt;collection&gt;`标签完成映射。这些方法解决了复杂数据关系的处理问题,提升了开发效率。
|
8月前
|
SQL XML Java
六、MyBatis特殊的SQL:模糊查询、动态设置表名、校验名称唯一性
六、MyBatis特殊的SQL:模糊查询、动态设置表名、校验名称唯一性
235 0
|
11月前
|
XML Java 数据库连接
Mybatis映射关系
简介:本文介绍了MyBatis框架中四种常见的关系映射方式,包括一对一、一对多、多对一及多对多。一对一通过简单属性映射实现;一对多通过在主对象中添加集合属性并使用`&lt;collection&gt;`标签映射子对象集合;多对一则利用`&lt;association&gt;`标签在主对象中映射单个子对象;多对多需引入第三方类,分别在两个主对象中添加对方的集合属性,并通过`&lt;collection&gt;`标签实现映射。
219 32
|
11月前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。