首页 > java > ibatis动态查询条件

ibatis动态查询条件

2011年2月25日 亲亲宝宝 发表评论 阅读评论

Ibatis的动态查询省的我们自己拼sql条件了,比我们常用的多个if语句方便多了。

应用场景,我们需要按照多个条件查询,比如:姓名、生日、地区等为条件

<select resultClass=”log”>

<![CDATA[elect rownum t.*

from TEST_User t

]]>

<dynamic prepend=” where “>

<isPropertyAvailable property=”userName”>

<isNotEmpty property=”userName” prepend=” and “>

t.username like ‘%$username$%’

</isNotEmpty>

</isPropertyAvailable>

<isPropertyAvailable property=”birth”>

<isNotEmpty property=”birth” prepend=” and “>

t.birth = #birth#

</isNotEmpty>

</isPropertyAvailable>

<isPropertyAvailable property=”area”>

<isNotEmpty property=”area” prepend=” and “>

t.username = #area#

</isNotEmpty>

</isPropertyAvailable>

</dynamic>

</select>

动态SQL的写法:

开始 <dynamic

条件成立时前面要加的字符串 prepend =”字符串”>

<属性关键字 (见下表)

prepend=”字符串”

判断条件的对象属性名 property=”字符串”

如果是属性关键字是比较条件时,字符串存放要比较的值compareValue=”字符串”>

要显示的条件名

</属性关键字>

结束</dynamic>

动态SQL的参数有:

属性关键字 含义
<isEqual> 如果参数相等于值则查询条件有效。
<isNotEqual> 如果参数不等于值则查询条件有效。
<isGreaterThan> 如果参数大于值则查询条件有效。
<isGreaterEqual> 如果参数等于值则查询条件有效。
<isLessEqual> 如果参数小于值则查询条件有效。如下所示:

<isLessEqual prepend = ”AND” property = ”age” compareValue = ”18” >

ADOLESCENT = ‘TRUE’

</isLessEqual>

<isPropertyAvailable> 如果参数有使用则查询条件有效。
<isNotPropertyAvailable> 如果参数没有使用则查询条件有效。
<isNull> 如果参数为NULL则查询条件有效。
<isNotNull> 如果参数不为NULL则查询条件有效。
<isEmpty> 如果参数为空则查询条件有效。
<isNotEmpty> 如果参数不为空则查询条件有效。参数的数据类型为CollectionString 时参数不为NULL或“”。如下所示:

<isNotEmpty prepend=”AND” property=”firstName” >

FIRST_NAME=#firstName#

</isNotEmpty>

<isParameterPresent> 如果参数类不为NULL则查询条件有效。
<isNotParameterPresent> Checks to see if the parameter object is not present (null). Example Usage:

<isNotParameterPresent prepend=”AND”>

EMPLOYEE_TYPE = ‘DEFAULT’

</isNotParameterPresent>

注意#和$的区别:

#xxx#  代表xxx是属性值,map里面的key或者是你的pojo对象里面的属性,ibatis会自动在它的外面加上引号,表现在sql语句是这样的 where xxx = ‘xxx’ ;

而$xxxx$ 则是把xxxx作为字符串拼接到你的sql语句中,比如 order by  topicId , 如果你不用$来拼接而用#的话,外面就会被加上引号的哦,比如你的语句这样写  … order by #xxx# (xxx就是你传进来的字符串topicId),ibatis 就会把他翻译成  order by ‘topicId’ 这样就报错了 ,用$的结果就是这样  order by topicId

分类: java 标签: 4,643 次阅读
原文链接:http://www.wenhq.com/article/view_679.html
欢迎转载,请注明出处:亲亲宝宝
  1. 本文目前尚无任何评论.
  1. 本文目前尚无任何 trackbacks 和 pingbacks.