c#获取带数组参数的存储过程出错

atszpp 2010-11-12 10:34:50
半夜求救了,大家帮帮忙看看咋回事
错误为“System.AccessViolationException: 尝试读取或写入受保护的内存。这通常指示其他内存已损坏。”

数据库定义:

create or replace package Pgl_interface is
type varchar2type is table of varchar2(255) INDEX BY BINARY_INTEGER;

procedure wx_interface (vUser in varchar2,
vOut out varchar2type,
nErr out number,
sErr out varchar2);

end pgl_interface;

create or replace package body Pgl_interface
is
procedure wx_interface (vUser in varchar2,
vOut out varchar2type,
nErr out number,
sErr out varchar2)
is
vStp_port_no varchar2(60);
begin
vStp_port_no:=vUser;
nErr:=0;
sErr:='';

for i in 1..50 loop
vOut(i):='0';
end loop;
end wx_interface ;

end Pgl_interface;


在C#代码为:

OracleConnection conn = new OracleConnection(strconn);
string[] strOut = new string[255];

conn.Open();
OracleCommand cmd = conn.CreateCommand();
cmd.CommandType = CommandType.StoredProcedure;
cmd.CommandText = "Pgl_interface.wx_interface";


OracleParameter p1 = new OracleParameter("vUser", OracleDbType.Varchar2);
p1.Value = strtest;
p1.Direction = System.Data.ParameterDirection.Input;

OracleParameter p2 = new OracleParameter("vOut", OracleDbType.Varchar2);
p2.CollectionType = OracleCollectionType.PLSQLAssociativeArray;
p2.ArrayBindSize = new int[255];
p2.Size = 255;
p2.Value = strOut;
p2.Direction = System.Data.ParameterDirection.Output;


OracleParameter p4 = new OracleParameter("nErr", OracleDbType.Int32);
p4.Value = code;
p4.Direction = ParameterDirection.Output;

OracleParameter p5 = new OracleParameter("sErr", OracleDbType.Varchar2);
p5.Value = desc;
p5.Direction = ParameterDirection.Output;

cmd.Parameters.Add(p1);
cmd.Parameters.Add(p2);
cmd.Parameters.Add(p4);
cmd.Parameters.Add(p5);

cmd.ExecuteNonQuery();
...全文
180 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
atszpp 2010-11-15
  • 打赏
  • 举报
回复
上班了,有人来看看么
atszpp 2010-11-14
  • 打赏
  • 举报
回复
OracleDbType有数组类型的吗?
p2.CollectionType = OracleCollectionType.PLSQLAssociativeArray;
不是访问数组的吗?
周公 2010-11-13
  • 打赏
  • 举报
回复
OracleDbType.Varchar2是数组类型吗?
atszpp 2010-11-12
  • 打赏
  • 举报
回复
别人提供给调用的,要是自己的早改了
rczjp 2010-11-12
  • 打赏
  • 举报
回复

你的存储过程比较特别
【更新至2025年】2001-2025年上市公司数字化转型年报词频统计(吴非、赵宸宇、甄红线)(300+年报词频统计) 1、时间:2001-2025年 2、来源:上市公司年报 3、参考文献:企业数字化转型与资本市场表现——来自股票流动性的经验证据(吴非) 数字化转型如何影响企业全要素生产率(赵宸宇) 知识产权行政保护与企业数字化转型(甄红线) 4、方法说明:(1)参考吴非老师的做法,对人工智能技术、大数据技术、云计算技术、区块链技术、数字技术运用五个维度76个数字化相关词频进行统计 (2)参考赵宸宇老师的做法,对数字技术应用、互联网商业模式、智能制造、现代信息系统四个维度99个数字化相关词频进行统计 (3)参考甄红线老师的做法,对技术分类、组织赋能、数字化应用等类别下139个数字化相关词频进行统计 5、指标:年份、股票代码、公司简称、行业名称、行业代码、全文-文本总长度、仅中英文-文本总长度、人工智能技术-吴、大数据技术-吴、云计算技术-吴、区块链技术-吴、数字技术运用-吴、数字技术应用-赵、互联网商业模式-赵、智能制造-赵、现代信息系统-赵、技术分类-人工智能技术-甄、技术分类-区块链技术-甄、技术分类-云计算技术-甄、技术分类-大数据技术-甄、组织赋能-人工智能技术-甄、组织赋能-云计算技术-甄、组织赋能-大数据技术-甄、组织赋能-广义数字技术-甄、数字化应用-技术创新-甄、数字化应用-流程创新-甄、数字化应用-业务创新-甄、人工智能、商业智能、图像理解、投资决策辅助系统、智能数据分析、智能机器人、机器学习、深度学习、语义搜索、生物识别技术、人脸识别、语音识别、身份验证、自动驾驶、自然语言处理、大数据、数据挖掘、文本挖掘、数据可视化、异构数据、征信、增强现实、混合现实、虚拟现实、云计算、流计算、图计算、内存计算、多方安全计算、类脑计算、绿色计算、认知计算等300+词频

111,131

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Creator Browser
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧