ADO在ORACLE中执行SQL问题(200分)

  • 主题发起人 主题发起人 holyszq
  • 开始时间 开始时间
H

holyszq

Unregistered / Unconfirmed
GUEST, unregistred user!
declare tt varchar2(30);
v_total number(8);
begin
tt :='043-28243154';
select count(*) into v_total from aa where awb_no= tt;
dbms_output.put_line(v_total);
end;


这段SQL 语句在PL/SQL 里面可以执行为什么放到ADOQuery里不能执行,哪位高手帮忙看一下,谢谢
 
顶一个,你在前面加上Begin 及#13#10,最后加上End;试试
 
谢谢szhcracker 你的回答,但是我没有明白你的意思! 因为这个SQL语句是在PL/SQL里面是不会报错的,但是我放在ADOQuery里就会报错
 
我的意思是类似于这样:
ADOQuery.SQL.Add('Begin ' + #13#10);
ADOQuery.SQL.Add(... + #13#10);
ADOQuery.SQL.Add('End; ' + #13#10);
ADOQuery.Open;//或者要用ADOQuery.Execute
不知是否可以。还有一个方法就是把你的SQL命令写成存储过程,然后调用即可了吧?
 
不行,这个我测试过了
 
自己顶一下
 
你把这句dbms_output.put_line(v_total);去掉看看是否会报错?如果不报错就是这句的问题,这句话在PL/SQL中确实是没有问题的,或者你可以把结果放到临时表中再检索出来,注意所有的命令(包括检索临时表的语句)都要在一个事务中提交
 
还有一个方法你可以试试:不要用ADO,用TRemoteSqlQuery来执行,方法如下
...
strs := TStringList.Create;
FRmtSQLQuery.ClearSQLParams;

for I := 0 to sqlList.Count - 1 do
begin
strs.Clear;
strs.Add(SQLList.Strings);
FRmtSQLQuery.AddSQLParams(strs);
end;
strs.Free;
FreeAndNil(sqlList);
try
FRmtSqlQuery.ExecuteSQL;
except
raise;
end;
...
 
dbms_output.put_line(v_total); 有测试过,还是不行,另外您说的用TRemoteSqlQuery来执行,这个控件能给我一份吗,谢谢 holyszq@163.com
 
我先试试。
 
谢谢!有结果希望告知!
 

Similar threads

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