微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

iReport 2.0.4:字符串类型参数在SQL查询中不起作用吗?

如何解决iReport 2.0.4:字符串类型参数在SQL查询中不起作用吗?

| 我正在处理iReport 2.0.4中的报告,该报告通过“ 0”连接到Oracle数据库,该数据库基于联合成员资格返回条目列表。该报告将开始日期,结束日期和联合名称作为参数。查询的基本结构是
select 
    ...
from
    ...
where
    union_opt_in_dt <= $P{EndDate} and
    union_opt_out_dt >= $P{StartDate} and
    union_name = $P{UnionName}
...
其中
StartDate
EndDate
的类型为
java.lang.Date
UnionName
的类型为
java.lang.String
。 问题是,如果我使用
UnionName
参数并传递并集名称(例如\“ AFScme \”),则查询将不返回任何数据。如果我删除“ 5”参数并对联合名称进行硬编码,如下所示
where
    union_opt_in_dt <= $P{EndDate} and
    union_opt_out_dt >= $P{StartDate} and
    union_name = \'AFScme\'
然后我得到该联盟名称的期望行。 那么,为什么日期参数有效,而字符串参数无效?我是否需要调用字符串参数(例如
.trim()
)才能使其工作? 更新,固定 在另一个解决该问题的论坛上找到另一个问题的答案;我必须对查询中的参数进行立即替换(术语?),因此需要
where
    union_opt_in_dt <= $P{EndDate} and
    union_opt_out_dt >= $P{StartDate} and
    union_name = \'$P!{UnionName}\'
这样可行。不确定我是否了解它的逻辑(大约一个半星期前我从未听说过Jasper Reports),但至少我可以继续前进。 更新更新,未修复 好的,上面的解决方案不是我所需要的;它仅替代认值,不一定替代传入的值。Argh。 为什么日期有效,但工会名称无效?我已经确保参数中的值与数据库中的值完全匹配,一个一个。     

解决方法

        通过之前,尝试修剪ѭ5。     

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。