从ADO.NET调用存储过程时,不能使用带有ParameterDirection的NVarChar类型的OracleParameter

我使用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();

如果我像这样执行它,我得到例外:

System.Exception: Parameter ‘message’: No size set for variable length data type: String.

我不担心. Oracle期望“message”参数的字符串长度.所以我在“message”参数上添加一个size参数:

var messageParam = new OracleParameter("message",OracleType.NVarChar,255) { Direction = ParameterDirection.Output};

然后当我运行它时,我得到这个System.Data.OracleClient.OracleException:

PLS-00306: wrong number or types of arguments in call to ‘VALIDATE_Bin’

我该怎么称呼这个程序并将消息传出去?我认为这个问题特定于字符串数据类型.这是一个错误吗?或者我做错了什么?

解决方法

尝试

var messageParam = new OracleParameter("message",OracleDbType.NVarchar2,UInt16.MaxValue) { Direction = ParameterDirection.Output};
messageParam.Value = dbnull.Value

相关文章

Java Oracle 结果集是Java语言中处理数据库查询结果的一种方...
Java AES和Oracle AES是现代加密技术中最常使用的两种AES加密...
Java是一种广泛应用的编程语言,具备可靠性、安全性、跨平台...
随着移动互联网的发展,抽奖活动成为了营销活动中不可或缺的...
Java和Oracle都是在计算机领域应用非常广泛的技术,他们经常...
Java 是一门非常流行的编程语言,它可以运行于各种操作系统上...