Mybatis动态构建Sql(无实体类)

本文介绍了Mybatis如何使用动态SQL来构建SQL语句,特别是在没有实体类的情况下。通过讲解if、choose(when,otherwise)、trim、where、set、foreach等元素的用法,展示了动态SQL在处理条件判断和参数安全方面的优势。同时,文章提到了update标签的statementType属性,解释了预编译与非预编译SQL的区别,并提供了动态替换表名和字段名的方法,使得可以对未知物理模型进行操作。
摘要由CSDN通过智能技术生成


先简单说下Mybatis的动态sql,这不是今天的重点。


MyBatis的动态SQL是基于OGNL表达式的,它可以帮助我们方便的在SQL语句中实现某些逻辑。


例如,sql语句where条件中,需要一些安全判断,例如按某一条件查询时如果传入的参数是空,此时查询出的结果很可能是空的,也许我们需要参数为空时,是查出全部的信息

MyBatis中用于实现动态SQL的元素主要有:

 

  • if
  • choose(when,otherwise)
  • trim
  • where
  • set
  • foreach
示例mapper.xml:

<select id="findActiveBlogLike"
	parameterType="BLOG" resultType="BLOG">
	SELECT * FROM BLOG
	WHERE
	<trim prefix="WHERE" prefixOverrides="AND |OR ">
		<choose>
			<when test="title != null">
				AND title like #{title}
			</when>
			<when test="author != null and author.name != null">
				AND title like #{author.name}
			</when>
			<otherwise>
				AND featured = 1
			</otherwise>
		</choose>
	</trim>
</select>

<update id="updateAuthorIfNecessary"
	parameterType="Author">
	update Author
	<trim prefix="where" prefixOverrides=","> 
	<set>
		<if test="username != null">username=#{username},</if>
		<if test="password != null">password=#{password},</if>
		<if test="email != null">email=#{email}</if>
	</set>
	where id=#{id}
	</trim>
</u
评论 76
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值