对ibatis标签<iterate>的理解,在看ibatis文档时,就看见过这个标签,并且还
对其不是很了解,一直没有到现在,在工作中用到了这个标签时,
才去了解了一下这个标签的具体含义。
先把文档中对该标签的介绍贴出来一起分享。
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。
我本人对上面<iterate>标签中内容的理解如下:
在生成该条sql语句时,<iterate>标签中的内容是循环生成的,就拿上面的例子来说,生成的sql是
(username=xxx1 or username=xxx2 or username=xxx 3)
而不是(username=xxx1 or xxx2 or xxx3)
再举个例子,如下:
id in
<iterate prepend="" property="ids" open="(" close=")" conjunction="," >
#ids[]#
</iterate> 。。。。。。。(1)
其生成的sql语句是:id in (xx1,xx2,xx3,.....),括号中的(包括括号)是<iterate>标签生成的。
<iterate>标签虽然是遍历整个集合的,但他也不象我们在java中用到的for一样,一次一次的
循环生成标签中的内容,而是一次性利用list或数组生成整个可运行的sql语句。
就好比(1)它生成的sql不可能象这样:id in (xx1)
id in (xx2) ,id in (xx3),.....
分享到:
相关推荐
标题中的“ibatis<iterate>标签”指的是在iBATIS框架中用于动态SQL的一个关键功能。iBATIS是一个优秀的持久层框架,它允许将SQL语句直接嵌入到Java代码中,简化了数据库操作。而`<iterate>`标签是iBATIS提供的一个...
在iBatis中,`<iterate>`标签是一个非常实用的功能,它允许我们处理集合数据,如数组、List或Map等,进行循环遍历并生成动态SQL语句。下面我们将详细探讨`<iterate>`标签的用法及其示例。 `<iterate>`标签的主要...
`<dynamic>`标签是iBATIS动态标签的核心,它允许在其内部包含一系列的条件标签,根据不同的条件来决定哪些部分应该被插入到最终的SQL语句中。`<dynamic>`标签有三个主要属性: 1. `prepend`: 在动态内容前添加的字符...
`<iterate>`标签是iBatis中用于循环遍历集合的一种机制,它允许你在SQL语句中动态生成参数列表,这对于批量操作(如批量插入、更新或删除)尤为重要。该标签支持多种属性,包括`property`、`conjunction`、`open`、`...
iBatis的配置文件支持`<iterate>`标签,该标签用于在XML映射文件中进行循环处理。 **2.1 情况一:多个输入参数循环次数不对称** 在这种情况下,如果某些参数只有一份,而其他参数有多份,可以通过创建一个新的...
上述示例中,`userNameList`是一个List类型的集合,`<iterate>`标签会遍历该集合中的所有元素,并为每个元素生成如下的SQL片段:`AND (username=#userNameList[0] OR username=#userNameList[1] OR ...)`。...
本文将详细介绍 ibatis 中 Dynamic SQL 的使用方法,特别关注 `<dynamic>` 标签及其相关的子标签。 #### 二、Dynamic SQL 标签概述 Dynamic SQL 在 ibatis 中主要通过以下几种标签实现: 1. **`<dynamic>`**:用于...
在ibatis 2.x中,Dynamic Sql的配置较为繁琐,需要使用特定的标签如`<isNotNull>`、`<iterate>`等来构建动态部分。例如,为了根据参数是否为空来决定是否包含某个条件,需要使用`<isNotNull>`标签,而对于集合参数的...
在这种情况下,`<iterate>`标签用于构建SQL的`IN`子句。`open`属性定义了`IN`子句的开始括号,`close`属性定义了结束括号,而`conjunction`属性定义了元素间的分隔符,通常是逗号。`#[]#`中的`[]`是占位符,Ibatis...
iBATIS通过`<iterate>`标签支持数组的遍历,将数组中的每个元素作为独立的值插入到SQL语句中。例如,`<iterate property="actionIds" open="(" close=")" conjunction=",">`这段代码会将`actionIds`数组中的每个元素...
9. **迭代器标签 `<iterate>`**: - `<iterate>`用于处理数组或集合类型的参数,如`dismissStatusList`,它可以生成逗号分隔的条件,如`m.DISMISS_STATUS in ( ... )`。 总结起来,这个Ibatis查询语句充分展示了...
第二种方法是利用iBatis提供的`iterate`标签,它可以遍历整个集合并为列表中的每个元素生成SQL的一部分。iBatis官方文档中给出了一个示例: ```xml <delete id="deleteList" parameterClass="java.util.List"> ...
<iterate conjunction=""> into SYS_TABLE (id, Category, Name, Code, Status) values (#[].Id#, #[].Category#, #[].Name#, #[].Code#, #[].Status#) </iterate> <!-- 也可以选择返回主键 --> select * ...
update Question set status=#status# <dynamic prepend="where questionId in"> <isNotNull property="actionIds"> <iterate property="actionIds" open="(" close=")" conjunction="," > #actionIds[]# </iterate...
在文档中,展示了如何使用<iterate>标签来生成IN子句,以便于将一个集合中的值动态地插入到SQL语句中。 7. 截止日期:在业务逻辑中,常常需要查询截止到某个特定日期或时间点的数据。iBatis配置允许使用动态SQL标签...
<pager:iterate property="pages" id="page"> <a href="<%= page %>"><%= page %></a> </pager:iterate> ``` 在JSP页面中使用这个自定义标签: ```jsp <pager:pager/> ``` 总结起来,"struts+spring+ibatis(SSI)...
iterate标签的基本语法是`<iterate property="collectionName" open="(" close=")" conjunction=","/>`,其中`property`指定了集合属性的名称,`open`和`close`定义了循环开始和结束的符号,`conjunction`则是元素...
在这个标签中,使用<isNotNull>标签确保只有当SDSALES_IDs非空时才执行删除操作,而<iterate>标签则用于迭代ID数组,并为每个ID生成IN子句中的参数: ```xml <delete id="DeleteManyT_LABEL_SDSALES" ...
Map<String, String> map = new HashMap<>(); map.put("name", "gaoxiang"); List<User> list = sqlMap.queryForList("getPeopleList", map); ``` 这里,`name`是参数名,对应的值是`gaoxiang`。在SQL语句中,`$...
这种方法使用iterate标签来批量插入数据,但是Oracle不支持一个insert语句中包含多个values的方式。这意味着,如果你想插入多行数据,你需要执行多个insert语句,这将导致性能问题。例如: ``` <insert id="insert_...