给 BIRT 的 SQL 数据集传多值参数

本文探讨了在 BIRT 中使用 JDBC 连接 MySQL 时遇到的多值参数传递问题,由于 JDBC 防止 SQL 注入的安全策略,导致无法直接传入多个值。解决方案是改用集算器 JDBC,它支持通过 SPL 脚本解决这一问题,使得复杂计算和性能提升成为可能。文中提供了相关资源帮助读者理解和快速上手集算器 JDBC 在 BIRT 中的应用。
摘要由CSDN通过智能技术生成

问题

在 BIRT 里通过 JDBC 连接 MYSQL,创建了个带参数的 SQL 数据集:

select*from tag where tag_name in (?)

期望传入多个逗号分割的值,又因为值是字符串类型,就给每个值加了单引号:'join','rank','group',但预览结果看不到数据,原因在于JDBC因为“预防SQL注入”的安全问题,禁止了这种多值参数的传值方式。

解答

那是不是所有JDBC都没有这种方便传多值参数的能力呢,换成集算器JDBC试试:

=connect("raqdoc").query("select * from tag where tag_name in ("+arg1+")")

arg1相当于第一个问号,然后看结果,能查出数据来了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值