Ibatis中的动态SQL:isNotNull,isPropertyAvailable,isNotEmpty用法

时间:2021-08-11 21:42:08

常用的几个关键字和属性: 
isNotNull 参数不为null时有效
isNotEmpty 参数不为null“”时有效
isPropertyAvailable 
如果参数有使用(paramMap中有这个key,不管value是null还是“”)则查询条件有效
prepend   <isNotNull prepend="and" property="firstName" >
生成的语句不会有多余的and,因为dynamic有一个隐藏的属性:removeFirstPrepend="true",所以一般要写上prepend="and",需要的时候它会自动去掉。

~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~  


Ibatis中的动态SQL,主要分为一元条件和二元条件查询: 

一元条件查询关键字: 
<isPropertyAvailable> 如果参数有使用则查询条件有效。 
<isNotPropertyAvailable>  如果参数没有使用则查询条件有效。 
<isNull>      如果参数为NULL则查询条件有效。 
<isNotNull>   如果参数不为NULL则查询条件有效。 
<isEmpty>     如果参数为空则查询条件有效。 
<isNotEmpty>  如果参数不为空则查询条件有效。参数的数据类型为Collection 
String 时参数不为NULL或“”。如下所示: 
<isNotEmpty  prepend=”AND” property=”firstName” > 
FIRST_NAME=#firstName# 
</isNotEmpty> 
一元元素的属性: 
prepend:可被覆盖的SQL语句组成部分,添加在语句的前面。 
property:被比较的属性 

二元条件查询关键字:<isEqual> 
如果参数相等于值则查询条件有效。 
<isNotEqual> 
如果参数不等于值则查询条件有效。 
<isGreaterThan> 
如果参数大于值则查询条件有效。 
<isGreaterEqual> 
如果参数等于值则查询条件有效。 
<isLessEqual> 
如果参数小于值则查询条件有效。如下所示: 
<isLessEqual  prepend = ”AND” property = ”age” compareValue = ”18” > 
ADOLESCENT = ‘TRUE’ 
</isLessEqual> 
二元元素的属性: 
prepend:  可被覆盖的SQL语句组成部分,添加在语句的前面。 
property:  被比较的属性 
compareProperty: 另一个被比较的属性 
compareValue:    被比较的值 
此外,还有其它的元素: 
1.<isParameterPresent> 
如果参数类不为NULL则查询条件有效。 
<isNotParameterPresent> 
Checks to see if the parameter object is not present (null). 
实例: 
<isNotParameterPresent prepend=”AND”> 
EMPLOYEE_TYPE = ‘DEFAULT’ 
</isNotParameterPresent>

 

2.动态iterate获取list下的对象

prepend - 可被覆盖的SQL语句组成部分,添加在语句的前面(可选)

property - 类型为java.util.List的用于遍历的元素(必选)

open - 整个遍历内容体开始的字符串,用于定义括号(可选)

close -整个遍历内容体结束的字符串,用于定义括号(可选)

conjunction - 每次遍历内容之间的字符串,用于定义AND或OR(可选)

#dealIdList[]#  []括号是必须的

 

[html] view plain copy
  1. <dynamic prepend="and">  
  2.   <isNotNull property="dealIdList">  
  3.       <iterate prepend="AND" property="dealIdList" open="(" close=")" conjunction="OR">  
  4.             d.DEAL_ID = #dealIdList[]#  
  5.       </iterate>  
  6.   </isNotNull>  
  7. </dynamic>  


最终生成的sql语句:DEAL_ID ‘1245’ or DEAL_ID ‘1246’ or DEAL_ID ‘1247’

 

如下使用ids是数组:

DEAL_ID  in

<iterate  prepend="" property="ids"  open="("  close=")"  conjunction="," >

               #ids[]#

  </iterate>

最终sql语句:DEAL_ID in (‘1234’,’1235’,’1236’)

 

3、动态intersect (取交集)

[html] view plain copy
  1. <dynamic prepend="INTERSECT SELECT DEAL_ID FROM DEAL_USER WHERE STATUS !='DELETED' AND" open="(" close=")">  
  2.          <isNotNull property="generalId">  
  3.                   <iterate prepend="AND" property="generalId" open="(" close=")" conjunction="OR">  
  4.                            GEN _ID = #generalId[]#  
  5.                   </iterate>  
  6.          </isNotNull>  
  7.          <isNotNull property="specificId">  
  8.                    <iterate prepend="OR" property="specificId" open="(" close=")" conjunction="OR">  
  9.                             SPEC _ID = #specific Id[]#  
  10.                    </iterate>  
  11.          </isNotNull>  
  12. </dynamic>   

4oracle union union allintersectminus

集合操作有 并,交,差 3种运算。

 union :得到两个查询结果的并集,并且自动去掉重复行。不会排序

 union all:得到两个查询结果的并集,不会去掉重复行。也不会排序

 intersect:得到两个查询结果的交集,并且按照结果集的第一个列进行排序

 minus:得到两个查询结果的减集,以第一列进行排序

例子:

  下面是两个表:一个主修课程表,一个选修课程表。

这个是主修课程表:minors

     create table minors(

         minor_id number primary key,

         minor_name varchar2(30) not null,

         credit_hour number(2)

      )

 

插入3条记录:               

  insert into minors values(10101,'计算机原理',4)

      insert into minors values(10201,'自动控制原理',3)

      insert into minors values(10301,'工程制图原理',4)

 

下面创建选修课程表minors2

 create table minors2(

         minor_id number primary key,

         minor_name varchar2(30) not null,

         credit_hour number(2)

       )

插入两条记录:

        insert into minors2 values(10201,'自动控制原理',3)

       insert into minors2 values(10301,'工程制图原理',4)  

两个表使用union all:得到如下结果

        select minor_id,minor_name,credit_hour from minors union all

       select minor_id,minor_name,credit_hour from minors2 order by     credit_hour

结果:   

MINOR_ID MINOR_NAME                     CREDIT_HOUR

---------- ------------------------------ -----------

     10201 自动控制原理                             3

     10201 自动控制原理                             3

     10101 计算机原理                               4

     10301 工程制图原理                             4

     10301 工程制图原理                             4

两个表使用union :得到如下结果

select minor_id,minor_name,credit_hour from minors union

 select minor_id,minor_name,credit_hour from minors2 order by credit_hour

结果:

MINOR_ID MINOR_NAME                     CREDIT_HOUR

---------- ------------------------------ -----------

     10201 自动控制原理                             3

     10101 计算机原理                               4

     10301 工程制图原理                             4

两个表使用intersect :得到如下结果

     select minor_id,minor_name,credit_hour from minors intersect

    select minor_id,minor_name,credit_hour from minors2

结果:

MINOR_ID MINOR_NAME                     CREDIT_HOUR

---------- ------------------------------ -----------

     10201 自动控制原理                             3

     10301 工程制图原理                             4

 

两个表使用minus :得到如下结果

    select minor_id,minor_name,credit_hour from minors minus

    select minor_id,minor_name,credit_hour from minors2

结果:

MINOR_ID MINOR_NAME                     CREDIT_HOUR

---------- ------------------------------ -----------

     10101 计算机原理                               4