FASTREPORT 如何在运行期间使用参数?(100分)

  • 主题发起人 主题发起人 lmtfw
  • 开始时间 开始时间
L

lmtfw

Unregistered / Unconfirmed
GUEST, unregistred user!
我建立了一个模板,在模板的ptDialog上放QUERY,BUTTON和参数取值的EDIT,在BUTTON中写SQL如下
QUERY.SQL.ADD('SELECT * FROM TABLE1')
QUERY.SQL.ADD('WHERE TABLE1.字段1=:AAA')
QUERY.PARAMBYNAME('AAA').ASSTRING:=EDIT.TEXT
可在第三行总通不过。如果在设计期间将SQL语句放在QUERY的SQL属性中,在PARAMS中设置参数取值则没问题。请问在FASTREPORT中是否不能使用PARAMBYNAME,如果这样我该怎么作?
谢谢!
 
你的上面通不过是有什么错误提示呢,不过单看语句就有很多问题哦
哦,假设你的报表中有一个name的变量,则可以这么赋值给它的
procedure TPrintMai_frm.frReport1GetValue(const ParName: string;
var ParValue: Variant);
begin
if ParName = 'name' then
ParValue := adoQry2.FieldValues['zgName'];
end;
 
frReport1GetValue这个应该在设计期间的吧
 
frReport1GetValue不是在设计期间的,而是在报表生成的时候触发。
 
在报表中的memo中填写[变量名]
在程序中 frvariables['变量名']:=变量数值
 
TO XJ2003 不行啊
 
你是用ADO还是BDE先?
 
>>请问在FASTREPORT中是否不能使用PARAMBYNAME
是的。在FR中的QUERY取參數用的是ParamText[Index: Integer]屬性。
 
to app2001 :bde
 
QUERY.SQL.ADD('SELECT * FROM TABLE1')
QUERY.SQL.ADD(' WHERE TABLE1.字段1=:AAA') //这行前面加个空格
QUERY.PARAMBYNAME('AAA').ASSTRING:=EDIT.TEXT
我认为和FR没多大关系呢?这个语句单独能不能执行成功先?
 
用Ado很方便的。
 

Similar threads

S
回复
0
查看
3K
SUNSTONE的Delphi笔记
S
S
回复
0
查看
2K
SUNSTONE的Delphi笔记
S
D
回复
0
查看
2K
DelphiTeacher的专栏
D
后退
顶部