动态Mapped Statement在iBATIS中应用

开发 后端
动态Mapped Statement在iBATIS中的应用是怎么样的呢?那么本文就向你介绍详细的内容。

动态Mapped Statement是如何在iBATIS中应用呢?让我们先看看实例:
 
Java代码

  1. ﹤select id="dynamicGetAccountList" cacheModel="account-cache" resultMap="account-result"﹥  
  2.   select * from ACCOUNT  
  3.   ﹤isGreaterThan prepend="and" property="id" compareValue="0"﹥  
  4.       where ACC_ID=#id#  
  5.   ﹤/isGreaterThan﹥  
  6.   order by ACC_LAST_NAME  
  7. ﹤/select﹥ 

例子说明:

如果值小于0,那么sql语句就是:
 
Java代码

  1. select * from ACCOUNT     
  2. order by ACC_LAST_NAME   

动态Mapped Statement应用更复杂的例子:
 
Java代码

  1. ﹤select id="dynamicGetAccountList"  resultMap="account-result"﹥     
  2.   select * from ACCOUNT     
  3.   ﹤dynamic prepend="WHERE"﹥     
  4.     ﹤isNotNull prepend="AND" property="firstName"﹥     
  5.      (ACC_FIRST_NAME=#firstName#     
  6.      ﹤isNotNull prepend="OR" property="lastName"﹥     
  7.        ACC_LAST_NAME=#lastName#     
  8.      ﹤/isNotNull﹥     
  9.      )     
  10.     ﹤/isNotNull﹥     
  11.     ﹤isGreaterThan prepend="and" property="id" compareValue="0"﹥     
  12.       ACC_ID=#id#     
  13.     ﹤/isGreaterThan﹥     
  14.   ﹤/dynamic﹥     
  15.   order by ACC_LAST_NAME     
  16. ﹤/select﹥   

动态Mapped Statement实例注解:

prepend:可被覆盖的SQL语句组成部分

property:被比较的属性

compareProperty:另一个用于和前者比较的属性
 
compareValue用于比较的值
 
﹤isEqual﹥

﹤isNotEqual﹥

﹤isGreaterThan﹥

﹤isGreaterEqual﹥

﹤isLessThan﹥

﹤isLessEqual﹥

﹤isPropertyAvailable﹥:检查是否存在该属性

﹤isNotPropertyAvailable﹥:
 
﹤isNull﹥:检查属性是否为null

﹤isNotNull﹥

﹤isEmpty﹥:检查Collection.size()的值,属性String或String.valueOf()值是否为null或空

﹤isNotEmpty﹥:

﹤isParameterPresent﹥:检查是否存在参数对象(不为null)

﹤iterate﹥遍历集合:
 
Java代码

  1. ﹤iterate prepend="and" property="userNameList" open="(" close=")" conjunction="or"﹥     
  2.   username=#userNameList[]#     
  3. ﹤/iterate﹥   

property属性:类型为java.util.List的用于遍历的元素

open属性:整个遍历内容开始的字符串,用于定义括号

close属性:整个便利内容结束的字符串

conjunction:每次遍历内容之间的字符串,用于定义AND或OR

动态Mapped Statement在iBATIS中的应用就向你介绍到这里,对它了解些了么?

【编辑推荐】

  1. iBATIS入门程序六大步详解
  2. iBATIS DAO事务浅析
  3. iBATIS使用$和#的一些理解
  4. iBATIS分页的一些理解
  5. iBATIS应用之SQLMap API编程浅析
责任编辑:仲衡 来源: JDNIS
相关推荐

2009-07-15 17:58:07

iBATIS 动态映射

2009-07-20 14:56:18

iBATIS.NET动态选择DAO

2009-07-15 13:11:25

ibatis动态查询

2009-07-22 11:11:39

iBATIS分页实例ObjectDataS

2009-07-17 10:32:45

iBATIS MapB

2009-07-22 13:04:41

iBATIS动态查询

2010-04-30 08:47:22

Oracle分页存储

2009-07-15 17:31:08

iBATIS Ecli

2009-07-16 13:08:09

iBATIS快速创建应

2009-07-17 10:59:59

iBATIS接口

2009-07-20 15:27:22

Castle.DynaiBATIS.NET

2009-07-14 17:12:26

ibatis自动代码生

2009-12-10 14:56:10

动态路由技术

2021-05-21 07:59:40

应用程序设计动态库函数

2012-07-16 01:41:54

ibatis搭建应用

2009-08-11 14:26:56

C#动态调用WebSe

2011-04-14 09:28:56

IIS 7.0

2010-11-12 13:08:36

动态sql语句

2009-07-17 14:55:38

ibatis官方

2009-07-16 13:50:31

ibatisResultMap
点赞
收藏

51CTO技术栈公众号