oracle执行sql没得结果也不报错
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle执行sql没得结果也不报错相关的知识,希望对你有一定的参考价值。
可能是SQL语句中存在语法错误,而Oracle数据库没有报错误,这是因为它在执行SQL语句时,已经将语法错误转换成了正确的语句。另外,在执行查询时,如果数据库中没有符合查询条件的数据,也不会报错,只是查询结果为空。 参考技术A 如果Oracle执行SQL没有得到结果也不报错,可能是SQL语句写错了、数据库中没有这个表或者表中没有这条记录等原因。建议检查SQL语句,并在确认无误的情况下重新执行。oracle存储过程中执行查询sql语句报错
Create Or Replace Procedure UP_ExecSqlProcForDS(strSql In Varchar2,cur_out Out sys_refcursor)
As
Begin
Open cur_out For
Execute immediate strSql;
End;
strSql是一条查询sql语句,类似于select * from table,我想要的是给存储过程传一个查询的sql语句,然后存储过程给我返回结果集,怎么弄?
CREATE OR REPLACE FUNCTION UP_ExecSqlProcForDS RETURN NUMBER IS
CURSOR tmcur_out IS
select *from table
;
begin
FOR l_cur IN tmcur_out LOOP
end loop
exception
end
这个只是框架,你自己可以 根据自己的需要作适当修改 参考技术B Open cur_out For strsql;
这个是么?
这是定义游标的使用方法,游标的语法是一个SELECT语句的字符串
type cursor_type is ref cursor;
c1 cursor_type;
open c1 for selectsql; 参考技术C CREATE OR REPLACE Procedure UP_ExecSqlProcForDS(strSql In Varchar2,cur_out Out sys_refcursor)
As
Begin
Open cur_out For
strSql;
End;本回答被提问者采纳 参考技术D 我空间有个关于存储过程的,看看能不能帮到你。
以上是关于oracle执行sql没得结果也不报错的主要内容,如果未能解决你的问题,请参考以下文章