birt如何实现SQL语句中带in的查询

woodphone 2011-06-27
最近弄个项目 需要用到birt 。。目前为止接触birt时间比较短。
项目中的报表比较复查。其中一个 需要用到 select * from XX where id in(?) 语句。   试过很多方法 发现都不能成功。 上网查找貌似也没找到什么关于这方面的 资料 故 咨询各位birt大神。。
具体如下:查询各个直属区域下的数据统计,传入的参数格式为 1,2,3,4 且不定长。
kang844850704 2011-08-27
可以考虑结合javascript代码来实现。
datamachine 2014-12-25
BIRT中对带in的查询的确比较复杂,由于BIRT不直接支持数组参数参与查询,即:无法把一个数组直接传给DataSet执行带in的SQL,所以你无法直接在数据集中把SQL写出来。

BIRT通过一个间接的方式来实现,首先在DataSet中定义选出所有数据的SQL(select * from XX),然后定义参数(如arg1,显示类型为List Box),允许多值,最后在DataSet的Script页签下选择beforeOpen事件,并编写如下JS脚本,进行SQL拼接(beforeOpen是指在数据集查询之前执行拼接SQL):

param = reportContext.getParameterValue("arg1");
tmp = "";
for(var i=0;i<param.length;i++){
tmp += param[i] + ",";
}
tmp = tmp.substring(0,tmp.length-1);
this.queryText += " where id in (" + tmp +")";

这样才可以得到带in的查询的数据集,很麻烦,这还是假定in的内容是数值型类型,如果是字符串或日期时间类,则还要再拼上引号等,就会更麻烦了。

如果可以直接使用数组参数参与查询将会非常简单,建议试试润乾的集算器,在集算器中接收参数组,直接传递给SQL进行查询,最后将结果返回给BIRT的DataSet进行直接报表展现。

类似的查询在集算器中可以这样做:
A1=db.query("select * from XX where id in (?)",arg1.array())
A2: result A1

集算器与BIRT可以无缝集成,和数据库一样用JDBC访问,可以参考http://blog.raqsoft.cn/?p=2663 .
Global site tag (gtag.js) - Google Analytics