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 . |