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

【问题】

最近弄个项目 需要用到 birt 。目前为止接触 birt 时间比较短。
项目中的报表比较复查。其中一个 需要用到 select * from XX where id in(?) 语句。 试过很多方法 发现都不能成功。 上网查找貌似也没找到什么关于这方面的 资料 故 咨询各位 birt 大神。
具体如下:查询各个直属区域下的数据统计,传入的参数格式为 1,2,3,4 且不定长。

【回答】

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 中接收参数组,直接传递给 SQL 进行查询,最后将结果返回给 BIRT 的 DataSet 进行直接报表展现。

比如类似的查询在集算器中可以这样做:


A

1

=db.query("select * from XX where id in (?)",arg1.array())

2

result A1


集算器与 BIRT 可以无缝集成,和数据库一样用 JDBC 访问,可以参考【BIRT 调用 SPL 脚本