首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 其他教程 > 操作系统 >

bboss 动态sql运用foreach循环示例

2012-06-26 
bboss 动态sql使用foreach循环示例本文介绍bboss 动态sql使用foreach循环示例。切入正题。在sql配置文件中配

bboss 动态sql使用foreach循环示例
本文介绍bboss 动态sql使用foreach循环示例。切入正题。
在sql配置文件中配置的sql语句有时需要用到foreach循环控制语句以及循环计数器velocityCount,以便遍历外部传入的list数据。在这里我们简单地介绍这个功能。

首先看看sql配置文件中配置的sql语句:

<property name="updateLkYjZt">  <![CDATA[   update dtjf.t_zt_zdry_cklkyjqbxx y set y.sjqszt = '5'  where y.yjlx='2'   and y.ldxxbh in (  #foreach($ldxxbh in $ldxxbhs)             #if($velocityCount == 1)             '$ldxxbh'                #else                    ,'$ldxxbh'             #end            #end        );  ]]></property>


在sql语句中包含了foreach循环控制语句和循环控制变量velocityCount:
#foreach($ldxxbh in $ldxxbhs)             #if($velocityCount == 1)             '$ldxxbh'                #else                    ,'$ldxxbh'             #end            #end      

其中的变量$ldxxbh 保存了每次迭代获取到的list元素的值,变量$ldxxbhs表示一个list集合,可以通过三种方式设置:bean的get方法,map对象,sqlparams对象;详情请参考文章《bbossgroups 持久层模板sql变量参数设置的三种方式》,本例采用map方式设定这个list类型变量$ldxxbhs。

下面我们看看java通过ConfigSQLExcutor对象executor来执行这个带foreach循环控制逻辑的sql语句代码:

public void updateLkYjZt(List<String> ldxxbhs) {try {Map datas = new HashMap();datas.put("ldxxbhs",ldxxbhs);executor.updateBean("updateLkYjZt", datas);} catch (SQLException e) {e.printStackTrace();}}


其中executor.updateBean("updateLkYjZt", datas)中的参数"updateLkYjZt"对应sql配置<property name="updateLkYjZt">中name属性的值,
Map对象datas中设置了key为“ldxxbhs”,值为list类型的变量ldxxbhs,foreach循环控制语句中通过key “ldxxbhs”来引用这个list对象,然后完成循环控制语句的执行。

热点排行