Java81883
lostfalling
采纳率100%
2019-11-25 10:05

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

5
已采纳

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条回答

  • caozhy 回答这么多问题就耍赖把我的积分一笔勾销了 2年前

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

    点赞 评论 复制链接分享