myBatis3之SQL映射的XML文件(动态SQL之二)

myBatis3之SQL映射的XML文件(动态SQL之二)

----------

 

if 

 

在动态SQL中所做的最通用的事情是包含部分where字句的条件。比如:

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

这条语句会提供一个可选的文本查找功能。如果你没有传递title,那么所有激活的博客都会被返回。但是如果你传递了title,那么就会查找相近的title(对于敏锐的检索,这中情况下你的参数值需要包含任意的遮掩或通配符)的博客。 

假若我们想可选地搜索title和author呢?首先,要改变语句的名称让它有意义。然后简单加入另外的一个条件。 如: 

<select id=”findActiveBlogLike” parameterType=”Blog” resultType=”Blog”> 
	SELECT * FROM BLOG WHERE state = 'ACTIVE' 
	<if test=”title != null”> 
		AND title like #{title} 
	</if> 
	<if test=”author != null and author.name != null”> 
		AND title like #{author.name} 
	</if> 
</select> 

 

 

 

 

你可能感兴趣的:(Mybatis3)