Jasper 怎么配置动态数据源
2021-02-19 07:18
标签:集算器 tab tac exec 需求 asc 获取 定义数据 key Jasper 本身是不支持动态数据源的,能用的解决方式是通过 api 自定义数据源,实际操作就是根据条件判断后动态设定 jdbc 的 url、用户名及密码等连接属性。比如: API 尽管做到了动态数据源, 但过程还是比较复杂的,另外还会导致自定义类与应用间高耦合,后期维护也是挺麻烦的事儿。 如果有集算器,这个问题就很容易处理,比如某业务量较大的企业把每年的数据都分库存放在独立服务器。当按年度查询数据(如订单表)的时候,就要动态的去连对应库。 集算器 SPL 一句话搞定 其中,“connect(dataSource)”为获取数据库连接,“dataSource”为集算器参数,传入哪年就可以获取对应数据库连接。 上面的场景还只是最简单的取数需求,如果涉及到多数据源的混合运算,对于 Jasper 来说就更困难了,甚至没解决方案。这些问题引入集算器都会变的轻松,感兴趣的可以参考:分库后的统计查询。 集算器提供了 JDBC 驱动,可以很方便的与 Jasper 等报表工具集成,详细用法可参考JasperReport 调用 SPL 脚本。 关于集算器安装使用、获得免费授权和相关技术资料,可以参见如何使用集算器。 Jasper 怎么配置动态数据源 标签:集算器 tab tac exec 需求 asc 获取 定义数据 key 原文地址:https://www.cnblogs.com/xiaohuihui-11/p/12935045.html String userName = userDetails.getUsername(); // obtain a connection based on the username.
String dataSourceURI = "";
if (userName.equalsIgnoreCase("admin")) {
dataSourceURI = "/datasources/ds_1";
userName = "xx";
… }
else if{…}
connection = getRepositoryDatasource(dataSourceURI);
try { parameterValues.put(JRParameter.REPORT_CONNECTION, connection.getDataSource().getConnection());
} catch (SQLException sqle){ sqle.printStackTrace(); }
A
B
C
1
=connect(dataSource)
/get dataSource connect
2
=A1.query(“select * from orders”)
/Execution query
上一篇:HTML5音乐播放器
下一篇:ES6-json与字符串的转换