ibatis动态SQL语句

 动态SQL语句
1)二元条件元素的属性:
    prepend  - 可被覆盖的 SQL 语句组成部分,添加在语句的前面(可选)
    property  - 被比较的属性(必选)
    compareProperty  -  另一个用于和前者比较的属性(必选或选择 compareValue)
    compareValue  -  用于比较的值(必选或选择 compareProperty)
<isEqual>                  比较属性值和静态值或另一个属性值是否相等。
<isNotEqual>          比较属性值和静态值或另一个属性值是否不相等。
<isGreaterThan>      比较属性值是否大于静态值或另一个属性值。
<isGreaterEqual>  比较属性值是否大于等于静态值或另一个属性值。
<isLessThan>          比较属性值是否小于静态值或另一个属性值。
<isLessEqual>          比较属性值是否小于等于静态值或另一个属性值。
例子:
<isLessEqual prepend=”AND” property=”age” compareValue=”18”>
    ADOLESCENT = 'TRUE'
</isLessEqual>
 
2)一元条件元素的属性:
    prepend  - 可被覆盖的 SQL 语句组成部分,添加在语句的前面(可选)
    property  - 被比较的属性(必选)
<isPropertyAvailable>          检查是否存在该属性(存在 parameter bean 的属性) 。
<isNotPropertyAvailable>  检查是否不存在该属性(不存在 parameter bean 的属性) 。
<isNull>                                  检查属性是否为 null。
<isNotNull>                              检查属性是否不为 null。
<isEmpty>                                  检查 Collection.size()的值,属性的 String 或 String.valueOf()值,
                                                    是否为 null或空( “”或size() < 1) 。
<isNotEmpty>                          检查 Collection.size()的值,属性的 String 或 String.valueOf()值,
                                                    是否不为 null 或不为空( “”或 size() > 0) 。
例子:
<isNotEmpty prepend=”AND” property=”firstName” >
    FIRST_NAME=#firstName#
</isNotEmpty>  

3)Iterate:这属性遍历整个集合,并为 List 集合中的元素重复元素体的内容。
    
    Iterate 的属性:
        prepend  - 可被覆盖的 SQL 语句组成部分,添加在语句的前面(可选)
        property  - 类型为 java.util.List 的用于遍历的元素(必选)
        open  -  整个遍历内容体开始的字符串,用于定义括号(可选)
        close  -整个遍历内容体结束的字符串,用于定义括号(可选)
        conjunction -  每次遍历内容之间的字符串,用于定义 AND 或 OR(可选)
        
    <iterate>  遍历类型为 java.util.List的元素。
                         例子:
                         <iterate prepend=”AND” property=”userNameList”
                                         open=”(” close=”)” conjunction=”OR”>
                                         username=#userNameList[]#
                         </iterate>
    
#注意:使用<iterate>时,在List元素名后面包括方括号[]非常重要,方括号[]将
    对象标记为List,以防解析器简单地将List输出成String。

例如:

<dynamic prepend="and (">
			<isNotNull prepend="or" property="bookMainNames">
				b.albumnamemain like
				<iterate property="bookMainNames"
					conjunction="or b.booknamemain like">
					'%$bookMainNames[]$%'
				</iterate>
			</isNotNull>
			<isNotNull prepend="or" property="bookNameApposes">
				b.bookNameAppose like
				<iterate property="bookNameApposes"
					conjunction="or b.bookNameAppose like">
					'%$bookNameApposes[]$%'
				</iterate>
			</isNotNull>
			<isNotNull prepend="or" property="bookNameVices">
				b.bookNameVice like
				<iterate property="bookNameVices"
					conjunction="or b.bookNameVice like">
					'%$bookNameVices[]$%'
				</iterate>
			</isNotNull>


 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值