如何解决ODP.NET将大字节数组传递给接受blob的PL / SQL存储过程
|| 我有一个接受BLOB参数(以及其他参数)的PL / sql存储过程,并执行将BLOB插入表中。如何将.NET中的大(1MB及更大)字节数组传递给存储过程。解决方法
从Oracle 11.2 / ODP.Net v2.112.1.2开始,您不能传递ѭ0数组。从Oracle®Data Provider for .NET开发人员指南11g第2版(11.2.0.3)中,PL / SQL关联数组绑定:
... ODP.NET支持PL / SQL关联数组的绑定参数
其中包含以下数据类型。
BINARY_FLOAT
CHAR
DATE
NCHAR
NUMBER
NVARCHAR2
RAW
ROWID
UROWID
VARCHAR2
将不支持的数据类型与关联数组一起使用会导致ORA-600错误。
还要注意:Oracle论坛:不支持传递BLOB的关联数组。
,设置SP查询(准备就绪)时,请将参数的数据类型设置为OracleDbType.Blob
。
OracleParameter p = query.CreateParameter();
p.OracleDbType = OracleDbType.Blob;
p.Direction = ParameterDirection.Input;
然后在运行查询之前,只需将参数的值设置为您提到的大BLOB。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。