现在的位置: 首页 > 综合 > 正文

一个简单的pb动态报表

2014年02月13日 ⁄ 综合 ⁄ 共 569字 ⁄ 字号 评论关闭

 这个简单的pb动态报表就是报表的列什么的都固定。但是查询条件可以随心所欲的设置。

首先做一个报表,最好不要排序,只写必要的条件。

然后再程序中根据具体的用户指定的条件构造一个where语句。

假设查询条件串在  中,即

g_print_sql =" where ?????? order by ?????"

然后我们重新构造查询语句

string my_sql=""
integer where_pos
my_sql=dw_2.getSqlselect()
where_pos=pos(my_sql,"WHERE")

if where_pos > 0 then
   my_sql=mid(my_sql,1,where_pos - 1) 
end if

g_print_sql = my_sql + g_print_sql

把最新的查询语句传输给报表,重新查询

dw_2.reset()
dw_2.SetSQLSelect(g_print_sql)
dw_2.retrieve()

这样,整个程序就搞定了。

开始的时候我没有去取原来的查询串进行截取,而是重新写的查询串。总是在查询的时候出错。说什么 powerbuilder only suports 18 decimal digits.我估计是现写的查询语句与原来的创建报表时给定的查询语句有不同之处。为了避免这个问题。我就想出了。取报表的原串截取,再附加新的查询条件的方法。

抱歉!评论已关闭.