ibatis动态SQL语句

最近参与了一个项目负责项目的二次开发,项目中用的是Ibatis .ibatis是mybatis的前身,在2010年7\8月份ibatis所项目移到了google,就将ibatis3.x正式改名为mybatis3.x了。虽然两者用法很相似,但是某些标签还是有差别,用惯了MyBatis,回头用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。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值