首页 > 解决方案 > SQL Server 存储过程返回值到字符串

问题描述

我有一个存储过程,它将返回SCOPE_IDENTITY()刚刚添加的行的 ID。

我已经从我的 C# 应用程序运行了该过程并将正确的数据添加到数据库中。我需要的是将此返回值存储为 C~ 中的字符串,以便我可以在 UI 中填充文本框。

SqlConnection con = new SqlConnection(connectionString);
con.Open();

SqlDataAdapter aa = new SqlDataAdapter("sp_insert_order", con);
aa.SelectCommand.CommandType = CommandType.StoredProcedure;
aa.SelectCommand.Parameters.Add("@customer_id", SqlDbType.VarChar, (50)).Value = comboBox1.SelectedItem;

aa.SelectCommand.ExecuteNonQuery();

con.Close();

变成

SqlConnection con = new SqlConnection(connectionString);
con.Open();

SqlDataAdapter aa = new SqlDataAdapter("sp_insert_order", con);
aa.SelectCommand.CommandType = CommandType.StoredProcedure;
aa.SelectCommand.Parameters.Add("@customer_id", SqlDbType.VarChar, (50)).Value = comboBox1.SelectedItem;

object oString = aa.SelectCommand.ExecuteScalar();

string myString = "";

if (oString != null)
{
    myString = oString.ToString();
    textBox1.Text = myString;
}

Textbox1 仍然是空白的。:(

标签: c#sql-server

解决方案


好的,我们假设您的 SProc 正常返回。尝试按如下方式分配输出参数:

SqlConnection cnx = new SqlConnection(WebConfigurationManager.ConnectionStrings["yourConnName"].ConnectionString);
SqlCommand cmd = new SqlCommand();
cmd.Connection = cnx;
cmd.CommandType = System.Data.CommandType.StoredProcedure;
cmd.CommandText = "testSProc";
cmd.Parameters.AddWithValue("name", "test Name");
SqlParameter outputParam = cmd.Parameters.Add("outID", SqlDbType.Int);
outputParam.Direction = ParameterDirection.Output;

object oString;

cnx.Open();
cmd.ExecuteNonQuery();
cnx.Close();

TextBox1.Text = outputParam.Value.ToString();

推荐阅读