<iterate>标签,顾名思义是用来遍历标签用的。

支持的属性如下:

属性 说明 是否必选
open 遍历后生成的这些sql,开始的第一个符号 可选
close 遍历后生成的这些sql,最后一个符号 可选
prepend 添加在open指定的符号前面 可选
property 被遍历的属性(往往是一个集合) 可选
conjunction 遍历后每一条sql之间的间隔 可选

各个击破,没有什么比例子最直接的了。

1. open 和close

insert into table (id,name) values<iterate open="(" close=")">   #ID#,#Name#</iterate>

不用考虑该语句的合理性,只是为了解释这两个属性随便写的,最终生成的SQL如下:

insert into table (id,name) values ('123','wh');

其中红色的两个括号,就是通过open 和close指定的。

2.conjunction-用于分割各个语句

select * from user where id in (
<iterate conjunction=",">
    #id#
</iterate>)

生成的SQL如下:

select * from user where id in (1,2,3,4,5);

其中红色的逗号  ,  就是通过conjunction指定的。

3. prepend-追加到最前面的内容

select * from user

<iterate prepend="WHERE" conjunction="AND">
  id=#id#
</iterate>

该语句更没啥价值,只为了说明该属性,生成SQL如下:

select * from user where id='1' and id='2' and id='3'

其中prepend指定的where会被添加在<iterate>标签的最前面,conjunction作为间隔符被添加在每一条语句中间。

4.property-官教说该变量是必须的,其实并不是必须的

如果有这么一个类定义:public class Dept{
   public string ID{get;set;}
   public List<User> Users{get;set;}
}

public class User{   public string ID{get;set;}   punlic string Name{get;set;}}
对应的sqlmp如下(property必须的情况):
<insert id="insert_u" parameterClass="Dept"> //指定parameterClass是Dept
  insert into user (id,name) values
    <iterate property="Users" conjunction=","> //设置property=Users,意思是要遍历的是Dept.Users属性
        (#Users[].ID#,#Users[].Name#) //因为Users是一个集合,所以写法要求Users[]的方式访问
    </iterate>
</insert>

//调用mapper.insert("isert_u",dept)

输出的SQL如下:

insert into user (id,name) values

('1','name1'),

('2','name2')

对应的sqlmp如下(property非必须的情况):
<insert id="insert_u" parameterClass="list"> //指定parameterClass是list,是一个集合
  insert into user (id,name) values
    <iterate conjunction=","> //不需要设置property,因为我们直接访问整个集合,而不是集合的某个属性
        (#[].ID#,#[].Name#) //因为本身是一个集合,所以写法要求[]的方式访问即可
    </iterate>
</insert>
//调用mapper.insert("isert_u",userList);

iBatisNet 中 iterate标签的使用的更多相关文章

  1. Html中<font>标签的使用

    Html中<font>标签的使用 <!doctype html> <html lang="en"> <head> <meta ...

  2. jsp2.0+中的标签文件,JSP Fragment技术

    刚进新公司不久,今天在看到项目中用到了.tag文件.刚开始我还以为这个是第三方类似freemarker的模板技术.问了下项目组的其他人员,原来这是jsp2.0以来就有的JSP Fragment技术.以 ...

  3. Html中<a>标签的样式的设置

    html中<a>标签的样式的设置.. ------------------------ <html> <head> <title>这是网页选项卡的名称& ...

  4. 禁止手机页面中A标签长按弹出路径框

    //禁止手机页面中A标签长按弹出路径框    window.onload=function(){        document.documentElement.style.webkitTouchCa ...

  5. JSP中<img>标签引用本地图片

    问题描述: jsp页面中<img>标签如何读取本地文件夹中的图片. 问题起因: 由于上传图片至本地文件夹中,图片路径为: D:/upload/file/image/img.jpg 所以将这 ...

  6. HTML中<meta>标签如何正确使用

    HTML中<meta>标签如何正确使用 如果我们在浏览器中按下F12或者Ctrl+shift+J,便可以打开开发者工具,在element中即可看到<head>元素中有不少< ...

  7. Jquery获取iframe子/父窗口中的标签

    获取子窗口中的标签: $("#id",document.frames('iframename').document); 获取父窗口中的标签: $('#id', parent.doc ...

  8. 在php中,如何将一个页面中的标签,替换为用户想输出的内容

    前言:釜山行,暴露人性, ———————————————————————————————————————————————————————————————————————————— 今天说一个最简单的例 ...

  9. JSP内置标签 JSP中JavaBean标签 JSP开发模式 EL和JSTL快速入门

    2 JSP内置标签(美化+业务逻辑)   1)为了取代<%%>脚本形式,使用JSP标签/JSP动作,目的:与JSP页面的美化,即JSP面页都是由标签组成,不再有其它的内容   2)JSP内 ...

随机推荐

  1. python 多线程拷贝单个文件

    # -*- coding: utf-8 -*- # @author: Tele # @Time : 2019/04/04 下午 12:25 # 多线程方式拷贝单个文件 import threading ...

  2. python 爬取豆瓣的美剧

    pc版大概有500条记录,mobile大概是50部,只有热门的,所以少一点 url构造很简单,主要参数就是page_limit与page_start,每翻一页,start+=20即可,tag是&quo ...

  3. const常量用extern声明定义的问题(extern变量不能在使用类里初始化)

    test.h #ifndef TEST_H_ #define TEST_H //常量声明和定义采取这种方法即可 const int a = 20;  //不报错,因为const变量链接属性默认是内部链 ...

  4. sparksql load/save

    java public class LoadAndSaveDemo { private static SparkConf conf = new SparkConf().setAppName(" ...

  5. range 的实现细节(start、end、step)(左闭右开区间)

    range(int start, int end, int step); 返回的区间是 [start, end) 要求步长为 step,三个参数均为整数, 在底层实现时,最终返回的区间元素的数目应当为 ...

  6. iOS开发 - OC - block的详解 - 基础篇

    深入理解oc中的block 苹果在Mac OS X10.6 和iOS 4之后引入了block语法.这一举动对于许多OC使用者的编码风格改变很大.就我本人而言,感觉block用起来还是很爽的,但一直以来 ...

  7. IIS与TOMCAT协同工作---在IIS下运行JSP页面

    转载:http://www.cnblogs.com/sjpisaboy/archive/2006/12/07/585749.html 最近碰到一个问题:我们实验室的一台IBM EServer服务器被运 ...

  8. google地图API的简单使用

    <div id="contact_container" style="width:700px;height:600px;"></div> ...

  9. TCP协议是如何保证可靠传输的【经典】

    参考:http://blog.csdn.net/cmm0401/article/details/77878998 从特点上我们已经知道,TCP 是可靠的但传输速度慢 ,UDP 是不可靠的但传输速度快. ...

  10. Power management in semiconductor memory system

    A method for operating a memory module device. The method can include transferring a chip select, co ...