`

MyBatis动态SQL

阅读更多

 转自 http://blog.csdn.net/a600423444/article/details/6658411

 

MyBatis动态SQL

 

动态SQL
MyBatis的动态SQL,解决了SQL字符串拼接的痛苦。

 

1.if

 

 

<select id="findActiveBlogWithTitleLike"
	parameterType="Blog" resultType="Blog">
	SELECT * FROM BLOG
	WHERE state = 'ACTIVE'
	<if test="title != null">
		AND title like #{title}
	</if>
</select>

 

 

这条一句会提供一个可选的文本查找功能。如果没有传递title,那么所有激活的博客都会被返回。
如果传递了title,那么就会查找相近的title。

 

2.choose,when,otherwise

 

 

<select id="findActiveBlogLike"
	parameterType="BLOG" resultType="BLOG">
	SELECT * FROM BLOG
	WHERE
	<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>
</select>

 

 

注:如果上述条件都没有匹配,则会变成SELECT * FROM BLOG WHERE
如果仅有第二个匹配,则会变成SELECT * FROM BLOG WHERE AND title LIKE somelike
显然这样会查询失败。要解决这个问题,mybatis提供了解决方法。

 

 

<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>

 

 overrides属性采用管道文本分隔符来覆盖,这里的空白是重要的。它的结果就是移除在InnerText中overrides中指定的内容。

 

3.set

<update id="updateAuthorIfNecessary"
	parameterType="Author">
	update Author
	<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}
</update>

 同上的问题,优化后:

<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>
</update>
 

 

分享到:
评论
1 楼 hpf_888 2013-11-02  
想问一下,注解的方式下,如何能实现动态sql效果?

相关推荐

    mybatis动态sql.zip

    mybatis动态sql,动态sql解析引擎,类似mybatis动态sql的功能。 mybatis动态sql,动态sql解析引擎,类似mybatis动态sql的功能。mybatis动态sql,动态sql解析引擎,类似mybatis动态sql的功能。mybatis动态sql,...

    mybatis 动态sql及参数传递

    在实际开发过程中,我们往往需要编写复杂的SQL语句,拼接稍有不注意就会导致错误,Mybatis给开发者提供了动态SQL,大大降低了拼接SQL导致的错误。 动态标签 if标签 if标签通常用那个胡where语句,update语句,insert...

    mybatis动态SQL语句

    if 、where、set、trim、choose 、foreach等在mybatis中的具体用法,有具体实例可供参考,玩转mybatis

    mybatis动态sql上传

    mybatis动态sql批量增删改查,增强了mybatis的认识。

    MyBatis动态SQL:构建灵活查询的利器.md

    内容概要:本文介绍了MyBatis动态SQL的基本概念、常用标签和使用技巧,帮助读者了解如何构建灵活的查询语句。 使用人群:适用于使用MyBatis框架进行数据库操作的开发者,尤其是需要构建复杂查询逻辑的开发者。 ...

    Mybatis动态sql

    Mybatis动态SQL实现,详细,简单,!

    mybatis动态sql.doc

    MyBatis 动态 SQL 是一种在 MyBatis 映射文件中使用条件语句来生成动态 SQL 语句的技术。它可以根据不同的条件生成不同的 SQL 语句,从而实现灵活的查询和操作。 在 MyBatis 中,可以使用 `&lt;if&gt;`、`&lt;choose&gt;`、`...

    mybatis动态SQL的详所有细用法代码。经过测试

    这是一个测试,专门测试Mybatis的动态sql。里面包含了所有的动态sql的用法,全部用代码形式描述出来,并给与适当的注释。

    mybatis动态SQL练习 动态查询 动态修改.zip

    mybatis动态sql 1.什么是动态SQL? Mabits是一个Java持久化框架,它提供了动态SQL的功能。动态SQL是一种根据不同条件动态生成SQL语句的技术。在Mabits中,动态SQL通常是通过使用一组特殊的标签和代码块来实现的,...

    springboot集成mybatis动态sql.zip

    mybatis动态sql 1.什么是动态SQL? Mabits是一个Java持久化框架,它提供了动态SQL的功能。动态SQL是一种根据不同条件动态生成SQL语句的技术。在Mabits中,动态SQL通常是通过使用一组特殊的标签和代码块来实现的,...

    Mybatis动态SQL高级映射.zip

    mybatis动态sql 1.什么是动态SQL? Mabits是一个Java持久化框架,它提供了动态SQL的功能。动态SQL是一种根据不同条件动态生成SQL语句的技术。在Mabits中,动态SQL通常是通过使用一组特殊的标签和代码块来实现的,...

    MyBatis动态SQL,MyBatis批量插入(Oracle数据库)[收集].pdf

    MyBatis动态SQL,MyBatis批量插入(Oracle数据库)[收集].pdf

    MyBatis 动态SQL.pdf

    mybatis动态sql 标签介绍

    mybatis之动态SQL

    mybatis之动态SQL

    MyBatis动态SQL详解.pdf

    mybatis动态sql 详解.pdf

    mybatis动态sql

    mybatis动态sql详解,网络查询,自己实践整理,希望对大家有帮助

    mybatis动态sql.md

    mybatis动态sql.md

    通过MyBatis动态SQL完成数据库表的增、删、改、查、模糊查询..zip

    mybatis动态sql 1.什么是动态SQL? Mabits是一个Java持久化框架,它提供了动态SQL的功能。动态SQL是一种根据不同条件动态生成SQL语句的技术。在Mabits中,动态SQL通常是通过使用一组特殊的标签和代码块来实现的,...

    mybatis动态sql(使用<where>标签来处理多个查询条件)

    mybatis动态sql mybatis动态sql(使用标签来处理多个查询条件)

Global site tag (gtag.js) - Google Analytics