从ADO.NET调用存储过程时,不能使用带有ParameterDirection的NVar
|
我使用ADO.Net来调用Oracle数据库中的存储过程.存储过程的out参数是NVARCHAR2.这是存储过程: CREATE OR replace PROCEDURE VALIDATE_Bin (
machine_dump_name IN NVARCHAR2,lpn IN NVARCHAR2,result OUT NUMBER,message OUT NVARCHAR2)
IS
BEGIN
IF lpn LIKE 'A%' THEN
result := 1;
message := NULL;
ELSE
IF lpn IS NULL THEN
result := 0;
message := 'Failed Read';
ELSE
result := 0;
message := 'Invalid Barcode';
END IF;
END IF;
END;
这里是填写命令参数的c#代码: command.Parameters.Add(new OracleParameter("machine_dumper_name",OracleType.NVarChar){Value = "My Dumper"});
command.Parameters.Add(new OracleParameter("lpn",OracleType.NVarChar) { Value ="XYZ1234"});
var resultParam = new OracleParameter("result",OracleType.Number) { Direction = ParameterDirection.Output};
command.Parameters.Add(resultParam);
var messageParam = new OracleParameter("message",OracleType.NVarChar) { Direction = ParameterDirection.Output};
command.Parameters.Add(messageParam);
command.ExecuteNonQuery();
如果我像这样执行它,我得到例外:
我不担心. Oracle期望“message”参数的字符串长度.所以我在“message”参数上添加了一个size参数: var messageParam = new OracleParameter("message",OracleType.NVarChar,255) { Direction = ParameterDirection.Output};
然后当我运行它时,我得到这个System.Data.OracleClient.OracleException:
我该怎么称呼这个程序并将消息传出去?我认为这个问题特定于字符串数据类型.这是一个错误吗?或者我做错了什么? 解决方法尝试var messageParam = new OracleParameter("message",OracleDbType.NVarchar2,UInt16.MaxValue) { Direction = ParameterDirection.Output};
messageParam.Value = DbNull.Value
(编辑:海洋资讯信息网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |

