首页 > 其他 > 详细

BIRT统一公用数据源、动态切换数据源解决方案

时间:2015-02-27 12:04:54      阅读:378      评论:0      收藏:0      [点我收藏+]

        通过BIRT报表工具开发出来的报表,在运行时往往是走一个统一的生产环境数据源,但是开发时往往是一个开发测试用的数据源,这就 需要随时能够在两个环境下进行切换。目前针对这个问题,公开可检索到的资料,基本上是通过数据源的beforeopen事件,通过写脚本的方式解决,这个 方式还是比较复杂,在报表数量较多,开发人数较多时,开发人员需要注意的地方还是有些多,并不完美。本文的处理方式,将能够根本性的解决该问题。

        不能在报表制作上做文章了,这样要么需要大量修改报表文件,要么需要每个报表继承一个公共的库文件,只能在BIRT的开放API上想办法了。通过研究BIRT的源代码,找到了如下解决方案,基本上完美的解决了这个问题。

IReportEngine birtEngine = ...;
IReportRunnable runnable = birtEngine.openReportDesign(...);
IRunAndRenderTask runAndRenderTask = birtEngine.createRunAndRenderTask(runnable);
Map appContext = runAndRenderTask.getAppContext();
Connection conn = ...;
appContext.put(IConnectionFactory.PASS_IN_CONNECTION,conn);

    这个方案需要在运行时手工获取连接,然后还需要注意处理连接的关闭等问题。

    这个方法已经在BIRT的4.2系列和4.4系列测试通过,BIRT的其他版本未验证。

    其实,这个appContext是BIRT的一个重要的开放扩展接口,通过它可以对BIRT的很多功能进行扩展和自定义。




BIRT统一公用数据源、动态切换数据源解决方案

原文:http://my.oschina.net/liyuj/blog/380305

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!