今天在调用C#程序中存储过程时,抛出奇怪的异常,描述为:String[4]: the size property has an invalid size of 0,看似与数据库操作无关,该存储过程中用到的parameter也都正确得进行了赋值。
google之后发现有不少人也都遇到过类似的问题,现对该问题及解决方法简要描述如下:
1、出现该问题的存储过程有一个特征,就是存在varchar类型的out参数,调用时对该参数的定义类似于
SqlParameter para = new SqlParameter("@paraname", DBType.String);
执行Excute时会抛出上述异常(注:网上有的人说是调用的Excute方法错误,应该调用ExcuteNonQuery而不是ExcuteScalar,自己验证了一下,不存在这个问题)
2、解决办法:该out参数必须有一个指定的长度,因此,应进行类似下面的初始化:
SqlParameter para = new SqlParameter("@paraname", DBType.String, size);
修改之后,问题解决
google之后发现有不少人也都遇到过类似的问题,现对该问题及解决方法简要描述如下:
1、出现该问题的存储过程有一个特征,就是存在varchar类型的out参数,调用时对该参数的定义类似于
SqlParameter para = new SqlParameter("@paraname", DBType.String);
执行Excute时会抛出上述异常(注:网上有的人说是调用的Excute方法错误,应该调用ExcuteNonQuery而不是ExcuteScalar,自己验证了一下,不存在这个问题)
2、解决办法:该out参数必须有一个指定的长度,因此,应进行类似下面的初始化:
SqlParameter para = new SqlParameter("@paraname", DBType.String, size);
修改之后,问题解决