c# 调用sql中带output的存储过程,本来是要返回一个“yes”结果只返回了一个"y",什么情况?

SQl的存储过程

create procedure mytry
(
@name nvarchar(50),
@number nvarchar(50),
@pr nvarchar(50) output
)
As
begin --
if exists (select name from persons where name = @name)
set @pr = 'yes' 
else
set @pr = 'no' 
end

c# 调用部分过```
conn.Parameters.Add("@name", SqlDbType.NVarChar).Value = "Ada";
conn.Parameters.Add("@number", SqlDbType.NVarChar).Value = "0";
conn.Parameters.Add("@pr", SqlDbType.NVarChar).Value = "0";           
conn.Parameters["@pr"].Direction = ParameterDirection.Output;

sqlcon.Open();
conn.ExecuteNonQuery();

//获得返回信息,显示在文本中
 txt.Text = conn.Parameters["@pr"].Value.ToString();
sqlcon.Close();


最后的调试结果,就只有一个“y”


![图片说明](https://img-ask.csdn.net/upload/201911/25/1574647402_459149.png)

1个回答

有一个Add的重载可以设置长度的,下面写法未必对,如果不对,你自己找找
conn.Parameters.Add("@pr", SqlDbType.NVarChar, 50).Value = "0";

Java81883
lostfalling 还真是那样,设置长度就ok了。
5 个月之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问