经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MyBatis » 查看文章
Mybatis动态SQL之where标签用法说明
来源:jb51  时间:2022/6/27 10:53:45  对本文有异议

关于where标签用法

xml映射文件部分内容:

  1. <select id="selectIfCondition" resultType="com.heiketu.testpackage.pojo.Product">
  2. ? ? SELECT
  3. ? ? ? ? prod_id prodId,
  4. ? ? ? ? vend_id vendId,
  5. ? ? ? ? prod_name prodName,
  6. ? ? ? ? prod_desc prodDesc
  7. ? ? FROM Products
  8. ? ? <where>
  9. ? ? ? ? <if test="prodId != null and prodId != ''">
  10. ? ? ? ? ? ? AND prod_id = #{prodId}
  11. ? ? ? ? </if>
  12. ? ? ? ? <if test="prodName != null and prodName != ''">
  13. ? ? ? ? ? ? AND prod_name = #{prodName}
  14. ? ? ? ? </if>
  15. ? ? </where>
  16. </select>

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

  1. SELECT
  2. ? ? prod_id prodId,
  3. ? ? vend_id vendId,
  4. ? ? prod_name prodName,
  5. ? ? prod_desc prodDesc
  6. FROM Products
  7. WHERE
  8. ? ? prod_id = ?
  9. AND
  10. ? ? prod_name = ?

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

  1. <select id="selectIfCondition" resultType="com.heiketu.testpackage.pojo.Product">
  2. ? ? SELECT
  3. ? ? ? ? prod_id prodId,
  4. ? ? ? ? vend_id vendId,
  5. ? ? ? ? prod_name prodName,
  6. ? ? ? ? prod_desc prodDesc
  7. ? ? FROM Products
  8. ? ? <where>
  9. ? ? ? ? <if test="prodId != null and prodId != ''">
  10. ? ? ? ? ? ? prod_id = #{prodId} AND
  11. ? ? ? ? </if>
  12. ? ? ? ? <if test="prodName != null and prodName != ''">
  13. ? ? ? ? ? ? prod_name = #{prodName} AND
  14. ? ? ? ? </if>
  15. ? ? </where>
  16. </select>

Mybatis会把次SQL语句拼接成:

  1. SELECT
  2. ? ? prod_id prodId,
  3. ? ? vend_id vendId,
  4. ? ? prod_name prodName,
  5. ? ? prod_desc prodDesc
  6. FROM Products
  7. WHERE
  8. ? ? prod_id = ? AND
  9. ? ? prod_name = ? AND

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

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

使用where标签及一些注意点

where标签简单使用

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

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

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

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

  1. // 此处为使用 where 标签SQL
  2. <select id="listConnection" parameterType="java.util.Map" resultMap="ResultMap">
  3. ? ? ? ? SELECT
  4. ? ? ? ? A.CONN_ID,
  5. ? ? ? ? A.CONN_NO,
  6. ? ? ? ? A.STA_ID,
  7. ? ? ? ? A.RUN_MODE,
  8. ? ? ? ? A.SRV_ID,
  9. ? ? ? ? A.LINE_ID
  10. ? ? ? ? FROM CONN A
  11. ?? ??? ?<where>?
  12. ?? ??? ??? ?<if test="srvId!= null">
  13. ?? ??? ??? ? A.SRV_ID= #{srvId,jdbcType=DECIMAL}
  14. ?? ??? ??? ?</if>?
  15. ?? ??? ??? ?<if test="runMode!= null">
  16. ?? ??? ??? ?AND ?A.RUN_MODE= #{runMode,jdbcType=VARCHAR}
  17. ?? ??? ??? ?</if>
  18. ?? ??? ?</where>
  19. </select>

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

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

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

  1. <select id="listConnection" parameterType="java.util.Map" resultMap="ResultMap">
  2. ? ? ? ? SELECT
  3. ? ? ? ? A.CONN_ID,
  4. ? ? ? ? A.CONN_NO,
  5. ? ? ? ? A.STA_ID,
  6. ? ? ? ? A.RUN_MODE,
  7. ? ? ? ? A.SRV_ID,
  8. ? ? ? ? A.LINE_ID
  9. ? ? ? ? FROM CONN A
  10. ?? ??? ?<where>?
  11. ?? ??? ??? ?A.CONN_ID=1
  12. ?? ??? ??? ?<if test="srvId!= null">
  13. ?? ??? ??? ?AND ? A.SRV_ID= #{srvId,jdbcType=DECIMAL}
  14. ?? ??? ??? ?</if>?
  15. ?? ??? ??? ?<if test="runMode!= null">
  16. ?? ??? ??? ?AND ?A.RUN_MODE= #{runMode,jdbcType=VARCHAR}
  17. ?? ??? ??? ?</if>
  18. ?? ??? ?</where>
  19. </select>

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

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号