Mybatis动态SQL之where标签用法说明

目录
  • 关于where标签用法
  • 使用where标签及一些注意点
    • where标签简单使用

关于where标签用法

xml映射文件部分内容:

<select id="selectIfCondition" resultType="com.heiketu.testpackage.pojo.Product">
    SELECT
        prod_id prodId,
        vend_id vendId,
        prod_name prodName,
        prod_desc prodDesc
    FROM Products
    <where>
        <if test="prodId != null and prodId != ''">
            AND prod_id = #{prodId}
        </if>
        <if test="prodName != null and prodName != ''">
            AND prod_name = #{prodName}
        </if>
    </where>
</select>

映射文件中的where标签可以过滤掉条件语句中的第一个and或or关键字。以上SQL当prodId!=null时会被mybatis的where标签去除掉多余的and关键字,生成的sql如下:

SELECT
    prod_id prodId,
    vend_id vendId,
    prod_name prodName,
    prod_desc prodDesc
FROM Products
WHERE
    prod_id = ?
AND
    prod_name = ?

注: where标签只能去除第一个条件中出现的前置 and 关键字。像以下情况,where就无能为力了:

<select id="selectIfCondition" resultType="com.heiketu.testpackage.pojo.Product">
    SELECT
        prod_id prodId,
        vend_id vendId,
        prod_name prodName,
        prod_desc prodDesc
    FROM Products
    <where>
        <if test="prodId != null and prodId != ''">
            prod_id = #{prodId} AND
        </if>
        <if test="prodName != null and prodName != ''">
            prod_name = #{prodName} AND
        </if>
    </where>
</select>

Mybatis会把次SQL语句拼接成:

SELECT
    prod_id prodId,
    vend_id vendId,
    prod_name prodName,
    prod_desc prodDesc
FROM Products
WHERE
    prod_id = ? AND
    prod_name = ? AND

where无法去除掉后面的and关键字,此时sql语句出现语法错误。

要想解决以上where标签无法处理的问题,可以考虑使用trim标签。

使用where标签及一些注意点

where标签简单使用

自己习惯性配上映射对象 这个大家根据自己习惯去写,可以直接使用map去接返回参数

// 返回对象映射
<resultMap id="ResultMap" type="com.xxx.root.ConnRoot">
        <result column="CONN_ID" property="connId" jdbcType="NUMERIC"/>
        <result column="CONN_NO" property="connNo" jdbcType="VARCHAR"/>
        <result column="STA_ID" property="staId" jdbcType="NUMERIC"/>
        <result column="RUN_MODE" property="runMode" jdbcType="VARCHAR"/>
        <result column="SRV_ID" property="srvId" jdbcType="NUMERIC"/>
        <result column="LINE_ID" property="lineId" jdbcType="NUMERIC"/>
</resultMap>
// 此处为使用 where相关SQL
<select id="listConnection" parameterType="java.util.Map" resultMap="ResultMap">
        SELECT
        A.CONN_ID,
        A.CONN_NO,
        A.STA_ID,
        A.RUN_MODE,
        A.SRV_ID,
        A.LINE_ID
        FROM CONN A 
        where 1=1 
        <if test="srvId!= null" >
        AND SRV_ID= #{srvId,jdbcType=DECIMAL}
        </if>
</select>

jdbcType 加上可以避免在映射时出现某些错误

jdbc出现的需求及 解决什么问题:当mybatis执行mapping文件时,如果某个映射的参数为空,无法确定他的类型时需要用到jdbcType来确定类型。

// 此处为使用 where 标签SQL
<select id="listConnection" parameterType="java.util.Map" resultMap="ResultMap">
        SELECT
        A.CONN_ID,
        A.CONN_NO,
        A.STA_ID,
        A.RUN_MODE,
        A.SRV_ID,
        A.LINE_ID
        FROM CONN A
        <where> 
            <if test="srvId!= null">
             A.SRV_ID= #{srvId,jdbcType=DECIMAL}
            </if> 
            <if test="runMode!= null">
            AND  A.RUN_MODE= #{runMode,jdbcType=VARCHAR}
            </if>
        </where>
</select>

到这里大家可以看到where标签使用和不适用的一些区别

首先是 where后面加 1=1,在使用where关键字时,因为条件不确定存在不存在,要加上 1=1这个垃圾条件来解决条件为空时where失去存在的意义;但是< where >标签中不需要加 1=1这个垃圾条件,因为where标签会自动处理只有在一个以上的< if >标签有值时才去插入“WHERE”子句到SQL中。

然后是另一个问题条件AND 条件,where标签会自动去除首个条件中的AND,这样大家就可以不用去管第一个条件是否为空可以直接给所有if标签中的条件都加上AND,但是自己还是习惯的将第一个条件去掉AND ,但是如果遇到前边已经有一个存在的条件的情况下,那接下来所有的if中的条件开头AND是必须要加的,如:

<select id="listConnection" parameterType="java.util.Map" resultMap="ResultMap">
        SELECT
        A.CONN_ID,
        A.CONN_NO,
        A.STA_ID,
        A.RUN_MODE,
        A.SRV_ID,
        A.LINE_ID
        FROM CONN A
        <where> 
            A.CONN_ID=1
            <if test="srvId!= null">
            AND   A.SRV_ID= #{srvId,jdbcType=DECIMAL}
            </if> 
            <if test="runMode!= null">
            AND  A.RUN_MODE= #{runMode,jdbcType=VARCHAR}
            </if>
        </where>
</select>

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • MyBatis深入解读动态SQL的实现

    目录 if和where trim Choose Set foreach mybatis最强大的功能之一便是它的动态sql能力 借用官方文档的一段话 : 如果您以前有使用JDBC或者类似框架的 经历,您就会明白把SQL语句条件连接在一起是多么的痛苦,要确保不能忘记空格或者不要在 columns列后面省略一个逗号等.动态语句能够完全解决掉这些痛苦. 那么如果没有这种功能到底有多痛苦呢 ? 我们来举例说明 这是一张表 , 试想如果我们通过 name 和 age来查询表信息时 , sql语句中肯定会存在

  • Mybatis超级强大的动态SQL语句大全

    目录 1. If 语句 2. Where语句 2.1 和 where 元素等价的自定义 trim 元素 3. Set语句 3.1 与 set 元素等价的自定义 trim 元素 4. Choose语句 5. Foreach语句 6. SQL片段 7. Bind元素 附:MyBatis配置动态SQL语句 总结 1. If 语句 需求:根据作者名字和博客名字来查询博客!如果作者名字为空,那么只根据博客名字查询,反之,则根据作者名来查询 <!--需求1: 根据作者名字和博客名字来查询博客! 如果作者名字

  • Mybatis超详细讲解构建SQL方法

    目录 1 SQL 构建对象介绍 1.1.1 介绍 1.1.2 实现准备 2 查询功能的实现 3 新增功能的实现 4 修改功能的实现 5 删除功能的实现 1 SQL 构建对象介绍 1.1.1 介绍 我们之前通过注解开发时,相关 SQL 语句都是自己直接拼写的.一些关键字写起来比较麻烦.而且容易出错. MyBatis 给我们提供了 org.apache.ibatis.jdbc.SQL 功能类,专门用于构建 SQL 语句 1.1.2 实现准备 编写指定调用方法 package com.yyl.sql;

  • 解析Mybatis对sql表的一对多查询问题

    Mybatisd对sql表的一对多查询 select * from projectrecord pr left join projects po on po.pid=pr.pid left join emp e on e.empno = pr.empno where pr.pid=1 <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.or

  • Mybatis中xml的动态sql实现示例

    目录 动态SQL简介 一.#{}与${}区别#{}表示一个占位符,使用占位符可以防止sql注入, 二.传递包装类型 三.动态sql—类型 四.动态sql—详解 (一)if 语句处理 (二)choose (when,otherwize)语句处理 (三)trim 语句处理 (四)where 语句处理 (五)foreach 语句处理 动态SQL简介 动态 SQL 是 MyBatis 的强大特性之一. 如果你使用过 JDBC 或其它类似的框架,你应该能理解根据不同条件拼接 SQL 语句有多痛苦,例如拼接

  • 关于Mybatis的sql注释问题

    Mybatis的sql注释 //mapper下的sql注释 package com.msb.mapper; import com.msb.pojo.Dept; import com.msb.pojo.Emp; import org.apache.ibatis.annotations.Delete; import org.apache.ibatis.annotations.Insert; import org.apache.ibatis.annotations.Select; import org

  • Mybatis在注解上如何实现动态SQL

    目录 在注解上实现动态SQL 注解的动态语句支持以下 注解方式动态sql写法和注意事项 判断字符串为空串 用单引号 大于等于用 小于等于用 在注解上实现动态SQL 使用Mybatis注解实现sql语句,但是有些时候有些字段是空的,这时候这个空的字段就要从条件查询语句中删除,这个时候就需要用到动态Sql. 注解的动态语句支持以下 trim where set foreach if choose when otherwise bind @Select({"<script> "

  • Mybatis详解动态SQL以及单表多表查询的应用

    目录 单表查询操作 参数占位符#{}和${} SQL 注入 like模糊查询 多表查询操作 一对一多表查询 一对多多表查询 动态SQL使用 if标签 trim标签 where标签 set标签 foreach标签 单表查询操作 参数占位符#{}和${} #{}:相当于JDBC里面替换占位符的操作方式(#{}->“”).相当于预编译处理(预编译处理可以防止SQL注入问题) ${}:相当于直接替换(desc这种关键字),但这种不能预防SQL注入 select * from userinfo where

  • Mybatis动态SQL之where标签用法说明

    目录 关于where标签用法 使用where标签及一些注意点 where标签简单使用 关于where标签用法 xml映射文件部分内容: <select id="selectIfCondition" resultType="com.heiketu.testpackage.pojo.Product">     SELECT         prod_id prodId,         vend_id vendId,         prod_name pr

  • MyBatis动态Sql之if标签的用法详解

    最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 本篇博客主要讲解如何使用if标签生成动态的Sql,主要包含以下3个场景: 1.根据查询条件实现动态查询 2.根据参数值实现动态更新某些列 3.根据参数值实现动态插入某些列 1. 使用if标签实现动态查询 假设有这样1个需求:根据用户的输入条件来查询用户列表,如果输入了用户名,就根据用户名模糊查询,如果输入了邮箱,就根据邮箱精确查询,如果同时输入了

  • MyBatis动态SQL标签用法实例详解

    1.动态SQL片段 通过SQL片段达到代码复用 <!-- 动态条件分页查询 --> <sql id="sql_count"> select count(*) </sql> <sql id="sql_select"> select * </sql> <sql id="sql_where"> from icp <dynamic prepend="where&quo

  • MyBatis动态SQL标签的用法详解

    1.MyBatis动态SQL MyBatis 的强大特性之一便是它的动态 SQL,即拼接SQL字符串.如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么痛苦.拼接的时候要确保不能忘了必要的空格,还要注意省掉列名列表最后的逗号.利用动态 SQL 这一特性可以彻底摆脱这种痛苦. 通常使用动态 SQL 不可能是独立的一部分,MyBatis 当然使用一种强大的动态 SQL 语言来改进这种情形,这种语言可以被用在任意的 SQL 映射语句中. 动态 SQL 元素和

  • MyBatis动态SQL中的trim标签的使用方法

    trim标记是一个格式化的标记,可以完成set或者是where标记的功能,如下代码: 1. select * from user <trim prefix="WHERE" prefixoverride="AND |OR"> <if test="name != null and name.length()>0"> AND name=#{name}</if> <if test="gender

  • MyBatis动态SQL foreach标签实现批量插入的方法示例

    需求:查出给定id的记录: <select id="getEmpsByConditionForeach" resultType="comtestbeansEmployee"> SELECT * FROM tb1_emplyee WHERE id IN <foreach collection="list" item="item_id" separator="," open="(&q

  • Mybatis入门教程(四)之mybatis动态sql

    推荐阅读: MyBatis入门学习教程(一)-MyBatis快速入门  什么是动态SQL? 动态SQL有什么作用? 传统的使用JDBC的方法,相信大家在组合复杂的的SQL语句的时候,需要去拼接,稍不注意哪怕少了个空格,都会导致错误.Mybatis的动态SQL功能正是为了解决这种问题, 其通过 if, choose, when, otherwise, trim, where, set, foreach标签,可组合成非常灵活的SQL语句,从而提高开发人员的效率. 下面就去感受Mybatis动态SQL

  • MyBatis 动态SQL和缓存机制实例详解

    有的时候需要根据要查询的参数动态的拼接SQL语句 常用标签: - if:字符判断 - choose[when...otherwise]:分支选择 - trim[where,set]:字符串截取,其中where标签封装查询条件,set标签封装修改条件 - foreach: if案例 1)在EmployeeMapper接口文件添加一个方法 public Student getStudent(Student student); 2)如果要写下列的SQL语句,只要是不为空,就作为查询条件,如下所示,这样

  • 自己动手实现mybatis动态sql的方法

    发现要坚持写博客真的是一件很困难的事情,各种原因都会导致顾不上博客.本来打算写自己动手实现orm,看看时间,还是先实现一个动态sql,下次有时间再补上orm完整的实现吧. 用过mybatis的人,估计对动态sql都不陌生,如果没有用过,就当看看热闹吧.我第一次接触mysql是在大四的时候,当时就觉得动态sql这东西很牛,很灵活,一直想搞明白怎么实现的,尽管当时已经能够写ioc,mvc和简单的orm框架(仿mybaits但是没有动态sql部分),但是仍然找不到mybatis核心的动态sql到底在哪

  • Mybatis4 之Mybatis动态sql的实现代码

    1.什么是动态SQL 传统的使用JDBC的方法,相信大家在组合复杂的的SQL语句的时候,需要去拼接,稍不注意哪怕少了个空格,都会导致错误.Mybatis的动态SQL功能正是为了解决这种问题, 其通过 if, choose, when, otherwise, trim, where, set, foreach标签,可组合成非常灵活的SQL语句,从而提高开发人员的效率. SQL语句不固定, 会根据前台用户的操作而进行变化的SQL语句, 可以被称之为动态SQL. 在MyBatis中, 提供了一组标签,

随机推荐