iBatisNet 中 iterate标签的使用
<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-追加到最前面的内容
<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标签的使用的更多相关文章
- Html中<font>标签的使用
Html中<font>标签的使用 <!doctype html> <html lang="en"> <head> <meta ...
- jsp2.0+中的标签文件,JSP Fragment技术
刚进新公司不久,今天在看到项目中用到了.tag文件.刚开始我还以为这个是第三方类似freemarker的模板技术.问了下项目组的其他人员,原来这是jsp2.0以来就有的JSP Fragment技术.以 ...
- Html中<a>标签的样式的设置
html中<a>标签的样式的设置.. ------------------------ <html> <head> <title>这是网页选项卡的名称& ...
- 禁止手机页面中A标签长按弹出路径框
//禁止手机页面中A标签长按弹出路径框 window.onload=function(){ document.documentElement.style.webkitTouchCa ...
- JSP中<img>标签引用本地图片
问题描述: jsp页面中<img>标签如何读取本地文件夹中的图片. 问题起因: 由于上传图片至本地文件夹中,图片路径为: D:/upload/file/image/img.jpg 所以将这 ...
- HTML中<meta>标签如何正确使用
HTML中<meta>标签如何正确使用 如果我们在浏览器中按下F12或者Ctrl+shift+J,便可以打开开发者工具,在element中即可看到<head>元素中有不少< ...
- Jquery获取iframe子/父窗口中的标签
获取子窗口中的标签: $("#id",document.frames('iframename').document); 获取父窗口中的标签: $('#id', parent.doc ...
- 在php中,如何将一个页面中的标签,替换为用户想输出的内容
前言:釜山行,暴露人性, ———————————————————————————————————————————————————————————————————————————— 今天说一个最简单的例 ...
- JSP内置标签 JSP中JavaBean标签 JSP开发模式 EL和JSTL快速入门
2 JSP内置标签(美化+业务逻辑) 1)为了取代<%%>脚本形式,使用JSP标签/JSP动作,目的:与JSP页面的美化,即JSP面页都是由标签组成,不再有其它的内容 2)JSP内 ...
随机推荐
- 【转】关于python中带下划线的变量和函数 的意义
http://www.blogjava.net/lincode/archive/2011/02/02/343859.html 总结: 变量: 1. 前带_的变量: 标明是一个私有变量, 只用于标明 ...
- as.data.frame一定要小心的一个參数stringsAsFactors
假设说一个data.frame中的元素是factor.你想转化成numeric,你会怎么做?比方d[1,1]是factor 正确答案是 先as.character(x) 再as.numeric(x ...
- JVM源码分析之System.currentTimeMillis及nanoTime原理详解
JDK7和JDK8下的System.nanoTime()输出完全不一样,而且差距还非常大,是不是两个版本里的实现不一样,之前我也没注意过这个细节,觉得非常奇怪,于是自己也在本地mac机器上马上测试了一 ...
- python2.x脚本转换为python3.x脚本的方法
版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/dushu990/article/details/73549174 python2.x脚本转换为pyt ...
- A GUIDE TO UNDERSTANDINGDISCRETIONARY ACCESS CONTROL INTRUSTED SYSTEMS
1. INTRODUCTION The main goal of the National Computer Security Center is to encourage the widespr ...
- 在Windows中安装MinGW-w64(有图,一步一步)
在Windows中安装MinGW-w64 发表回复 如需配合Sublime Text 3编译C程序, 请参考本站文章: 使用Sublime Text 3与MinGW-w64编译C语言程序 MinGW, ...
- jQuery插件接口的实现,jquery.extend
http://www.imooc.com/code/3403 如果jQuery没有插件接口的设计,那么他就像个光杆司令没有兵,就是没有手下,只有自己一个封闭的城堡.因此jQuery城堡需要设计一个大门 ...
- 浏览器兼容性之ECMAScript
1 IE中不能操作TR标签的innnerHTML. 2 日期处理函数不一致. (1)IE 8- new Date().getYear()返回的是到当前日期到1900年的差值,FF返回的是当前的年. ( ...
- c语言bit倒置最好的算法-离msb-lsb至lsb-msb
问题 什么是例如最好的算法,下面的转换? 0010 0000 => 0000 0100 从详细的转换MSB->LSB至LSB->MSB, 所有的Bit必须扭转,着.这并非字节顺序的交 ...
- Windows下静态编译Qt4
既然是静态编译,那就要编译出来的程序不信赖于任何dll文件.首先下载qt-win-opensource-4.7.4-mingw.exe: http://get.qt.nokia.com/qt/sour ...