#Mybatis 之 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标签使用和不适用的一些区别

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

到这里就结束了,大家如果有啥问题,可以私信,在看到如果能有好的解决办法第一时间跟大家沟通,谢谢观看。

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐