我有一个这样定义的 SQL 函数:
create or replace function func_cmap_unit_test
(what varchar2)
return varchar2 as
begin
return 'hello ' || what || '!';
end func_cmap_unit_test;
我在 SQL Developer 中测试过,它工作正常:
select portal_ops.func_cmap_unit_test('world') from dual;
我有以下 C# 代码:
Command.CommandText = funcName;
Command.CommandType = CommandType.StoredProcedure;
Command.Parameters.Add(
new OracleParameter
(
"Output"
, TypeMapping[typeof(T)]
//, OracleDbType.Clob
, ParameterDirection.ReturnValue
)
);
foreach ((string name, object value) param in spParams)
{
Command.Parameters.Add(param.name, param.value);
}
if (Command.Connection.State == ConnectionState.Closed)
{
Command.Connection.Open();
}
Command.ExecuteNonQuery();
return (T)Command.Parameters[0].Value;
问题是Command.ExecuteNonQuery
不断失败
ORA-06502: PL/SQL: 数字或值错误: 字符串缓冲区太小
正如您在注释代码中看到的那样,当我切换OracleDbType
到 时Clob
,ExecuteNonQuery
通过了。我很困惑为什么它不起作用OracleDBType
。任何帮助是极大的赞赏。