所以我正在开发一个Web服务,它将使用两个调用数据库的函数从数据库中获取数据。我们的目标是让它如果其中一个参数中有一个特定值,那就说
bool x= false;
if ( "Y".Equals( parameterValve, StringComparison.InvariantCultureIgnoreCase ) )
x= true;
if ( x)
cmd.Parameters.Add( "function_call1", OracleType.Cursor ).Direction = ParameterDirection.Output;
else
cmd.Parameters.Add( "function_call2", OracleType.Cursor ).Direction = ParameterDirection.Output;
try
{
grab data here
}
return to webservice
我已经完成了所有这些设置,它适用于第一个参数。但是,当我使用第二个参数调用调用webservice时,我收到此错误。
System.Data.OracleClient.OracleException: ORA-06503: PL/SQL:
Function returned without value
ORA-06512: at "database.package", line 103
ORA-06512: at line 1
我的问题是这个错误发生的原因究竟是什么? 是因为我正在调用函数不正确或者函数调用本身是否有错误?
基本上我已经盯着这段代码了一段时间,现在试图找出我做错了什么,所以我希望有人能够指出我正确的方向我应该寻找纠正此错误。
非常感谢任何帮助或建议。
谢谢!
答案 0 :(得分:7)
功能本身有问题。
不知何故,Oracle正在完成该功能而不返回任何内容。例如,如果传入1个参数并且如果在
中传递了两个参数则抛出ORA-6503错误,则此函数将成功运行CREATE OR REPLACE FUNCTION throw_error( p_arg1 IN NUMBER,
p_arg2 IN NUMBER DEFAULT null )
RETURN NUMBER
IS
BEGIN
IF( p_arg2 IS NULL )
THEN
RETURN 1;
END IF;
END;
SQL> select throw_error(1) from dual;
THROW_ERROR(1)
--------------
1
SQL> select throw_error(1,2) from dual;
select throw_error(1,2) from dual
*
ERROR at line 1:
ORA-06503: PL/SQL: Function returned without value
ORA-06512: at "HR.THROW_ERROR", line 10
ORA-06512: at line 1