Ibatis中的动态SQL:isNotNull,isPropertyAvailable,isNotEmpty用法详解编程语言
常用的几个关键字和属性:
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
? dynamic prepend= and isNotNull property= dealIdList iterate prepend= AND property= dealIdList open= ( close= ) conjunction= OR d.DEAL_ID = #dealIdList[]# /iterate /isNotNull /dynamic
dynamic prepend="and" isNotNull property="dealIdList" iterate prepend="AND" property="dealIdList" open="(" close=")" conjunction="OR" d.DEAL_ID = #dealIdList[]# /iterate /isNotNull /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
? dynamic prepend= INTERSECT SELECT DEAL_ID FROM DEAL_USER WHERE STATUS != DELETED AND open= ( close= ) isNotNull property= generalId iterate prepend= AND property= generalId open= ( close= ) conjunction= OR GEN _ID = #generalId[]# /iterate /isNotNull isNotNull property= specificId iterate prepend= OR property= specificId open= ( close= ) conjunction= OR SPEC _ID = #specific Id[]# /iterate /isNotNull /dynamic
dynamic prepend="INTERSECT SELECT DEAL_ID FROM DEAL_USER WHERE STATUS !=DELETED AND" open="(" close=")" isNotNull property="generalId" iterate prepend="AND" property="generalId" open="(" close=")" conjunction="OR" GEN _ID = #generalId[]# /iterate /isNotNull isNotNull property="specificId" iterate prepend="OR" property="specificId" open="(" close=")" conjunction="OR" SPEC _ID = #specific Id[]# /iterate /isNotNull /dynamic
4、oracle union、 union all、intersect、minus
集合操作有 并,交,差 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
13585.html
cgojavaoraclexml相关文章
- SQL Prompt10 安装激活教程,让你写sql 如鱼得水[通俗易懂]
- SQL去重语句_sql中文
- Spark-Sql源码解析之二 Sqlparser:sql –> unresolved logical plan详解大数据
- JDBC: 批量处理提高SQL处理速度详解编程语言
- mybatis 模糊查询简单sql详解编程语言
- ibatis配置log4j输出sql语句等日志信息详解编程语言
- 删除Oracle数据库中的列——SQL实现(oracle删除列sql)
- django原生SQL语句查询与前端数据传递详解编程语言
- Mybatis控制台打印SQL语句的两种方式详解编程语言
- ST05 跟踪SQL详解编程语言
- ABAP 7.40, SP08 中的 Open SQL 新特性详解编程语言
- ABAP 7.52 中的Open SQL新特性详解编程语言
- java.uti.Date与java.sql.Date 区别详解编程语言
- MSSQL导出数据到SQL:实现快速简单的数据迁移(mssql导出sql)
- 解决解开Oracle疑难SQL之谜(oracle疑难sql)
- SQL优化手段之MSSQL极致优化(sql优化 mssql)
- Oracle SQL跟踪工具的使用指南(oracle跟踪sql工具)
- 25字中文文章标题:Oracle跟踪SQL工具使用详解(oracle跟踪sql工具)
- 在MySQL命令行中导入SQL文件(mysql命令行导入sql文件)
- Oracle 减法运算一次性解决复杂SQL问题(oracle 减法sql)
- Oracle如何利用SQL快速写出时间表达式(oracle写时间sql)
- MySQL中涵盖的SQL操作详解(mysql中包含的sql)
- SQL访问Redis新技术所带来的变革(sql 访问 redis)
- 如何在MySQL中运行SQL查询(mysql上运行sql)
- Oracle数据库如何防范SQL注入(oracle会sql注入)
- Oracle数据库下Sql命令简易使用指南(Oracle下sql帮助)