mybatis动态SQL中的sql片段

谁说胖子不能爱 提交于 2019-12-03 14:15:08

https://www.cnblogs.com/qiankun-site/p/5762352.html

在mybatis中通过使用SQL片段可以提高代码的重用性,如下情景:

  1、创建动态SQL

    <sql id="sql_count">select count(*)</sql>

  2、使用

    <select id="selectListCountByParam" parameterType="map" resultType="String">

      <include refid="sql_count"/> from table_name

    </select>

  3、解析

    在使用sql片段时使用include标签通过sql片段的id进行引用,sql片段的ID在当前空间必须为唯一的

    当然,sql片段中也可以写其他的内容,只要符合语法规范都是可以的。如下:
    <sql id="sql_where">
      <trim prefix="WHERE" prefixoverride="AND | OR">
        <if test="id != null">AND id=#{id}</if>
        <if test="name != null and name.length()>0">AND name=#{name}</if>
        <if test="gender != null and gender.length()>0">AND gender=#{gender}</if>
      </trim>
    </sql>


    <select id="updateByKey" parameterType="Map" resultType="List">
      select * from user 
      <include refid="sql_where">
    </select>

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!