使用Query组件时,运行程序,关闭含有Query组件的窗口时,出现错误信息list index out of bounds!请问是何原因如何解决?(50分)

  • 主题发起人 主题发起人 chowchow
  • 开始时间 开始时间
C

chowchow

Unregistered / Unconfirmed
GUEST, unregistred user!
使用Query组件时,运行程序,关闭含有Query组件的窗口时,
出现错误信息list index out of bounds!请问是何原因如何解决?
调用SQl语句时,用query1.sql.add('selec * from edu where pxnr like "%:px%"')
时也出错,请问如何在add语句中使用含有变量的模糊查询。
谢谢!
 
like ''%'+vV+'%'''
至于错误信息,肯定和与Query联系的东西有关。
错误信息是超出边界错误。
 
query3.close;
query3.sql.clear;
query3.SQL.add('select * from edu where xldm=2');
query3.open;
在dbgrid可以得到数据
而用
query3.close;
query3.sql.clear;
query3.SQL.add('select * from edu where xldm=:xldm');/query3.params[0].value.type:=integer;
query3.Params.paramvalues['xldm']:=2;
open;
却不行,其中xldm在表中为number(4)数据类型。
请问为什么?
(注:其它数据类型如varchar2(30)上述两种方法都行)
 
query3.Params.paramvalues['xldm']:=2;之前用
query3.createparam试一试,可能先要创建参数才行
 
在add语句中使用含有变量的模糊查询:
将非变量语句与变量做字符串处理即可,不能将变量放在引号中。
.add('select * from 表 where 字段 like' + '''%' + 变量 + '%''')
 
ckzn说得非常正确,多谢多谢
 
多人接受答案了。
 

Similar threads

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