从C#Code-Behind触发的SQL存储过程无法在UPDATE上运行

时间:2011-06-26 01:29:22

标签: c# .net asp.net sql stored-procedures

我有一个从C#代码隐藏调用的存储过程。代码触发但不执行更新命令。存储过程如果直接运行,则有效。我想我的脑屁。请帮忙。

代码:

protected void btnAbout_Click(object sender, EventArgs e)
{
    SqlConnection myConnection = new SqlConnection(strConnection);
    SqlCommand myCommand = new SqlCommand("spUpdateCMSAbout", myConnection);
    myConnection.Open();
    myCommand.CommandType = CommandType.StoredProcedure;
    myCommand.Parameters.Add("@AboutText", SqlDbType.NVarChar, -1).Value = txtAbout.Text.ToString();
    myCommand.ExecuteNonQuery();
    myConnection.Close();
}

存储过程:

ALTER PROCEDURE fstage.spUpdateCMSAbout
(
   @AboutText nvarchar(max)
)
AS
BEGIN
SET NOCOUNT ON;
    UPDATE fstage.staticCMS SET About = @AboutText;
END

标记:

<asp:Button ID="btnAbout" runat="server" 
    Text="Save" CausesValidation="False" onclick="btnAbout_Click" 
    UseSubmitBehavior="False" />

C#.NET 4.0

3 个答案:

答案 0 :(得分:4)

您的代码应该有效。但是,您可以稍微简化它并使其更加健壮:

using(var myConnection = new SqlConnection(strConnection))
using(var myCommand = myConnection.CreateCommand())
{
    myCommand.CommandText = "spUpdateCMSAbout";
    myCommand.CommandType = CommandType.StoredProcedure;
    myCommand.Parameters.AddWithValue("AboutText", txtAbout.Text);
    myConnection.Open();
    myCommand.ExecuteNonQuery();
}

如果没有,请尝试直接调用UPDATE来绕过存储过程:

using (var myConnection = new SqlConnection(strConnection))
using (var myCommand = myConnection.CreateCommand())
{
    myCommand.CommandText = "UPDATE fstage.staticCMS SET About = @AboutText";
    myCommand.Parameters.AddWithValue("AboutText", txtAbout.Text);
    myConnection.Open();
    myCommand.ExecuteNonQuery();
}

如果它不起作用,可能UPDATE fstage.staticCMS SET About = 'something'因为某种触发而无法做任何事情。

答案 1 :(得分:0)

我总是运行SQL Server Profiler并在数据库上设置跟踪。您可以确定您的数据库是否正在获取查询。如果是,那么你知道问题在你的数据库中,如果不是,那么你知道它是你的代码。

答案 2 :(得分:-1)

protected void uiUpdateButton_Click(object sender, EventArgs e) {
    using(SqlConnection con = new SqlConnection(connstring)) {

        con.Open();

        SqlCommand cmd = new SqlCommand("usb_update_empdtls", con);
        cmd.CommandType = CommandType.StoredProcedure;
        cmd.Parameters.Add("@EmployeeID", SqlDbType.NVarChar, -1).Value = TextBox1.Text.ToString();
        SqlParameter parEmployeeID = AddInputParameters("@EmployeeID", SqlDbType.Int, 10, ParameterDirection.Input, TextBox1.Text);

        SqlParameter parLastName = AddInputParameters("@LastName", SqlDbType.VarChar, 20, ParameterDirection.Input, TextBox2.Text);
        SqlParameter parFirstName = AddInputParameters("@FirstName", SqlDbType.VarChar, 20, ParameterDirection.Input, TextBox3.Text);
        SqlParameter parTitle = AddInputParameters("@Title", SqlDbType.VarChar, 100, ParameterDirection.Input, TextBox4.Text);
        SqlParameter parPresentAddress = AddInputParameters("@PresentAddress", SqlDbType.VarChar, 60, ParameterDirection.Input, TextBox5.Text);
        SqlParameter parCity = AddInputParameters("@City", SqlDbType.VarChar, 50, ParameterDirection.Input, TextBox6.Text);
        SqlParameter parPostalCode = AddInputParameters("@PostalCode", SqlDbType.VarChar, 10, ParameterDirection.Input, TextBox7.Text);
        SqlParameter parCountry = AddInputParameters("@Country", SqlDbType.VarChar, 50, ParameterDirection.Input, TextBox8.Text);
        SqlParameter parExtension = AddInputParameters("@Extension", SqlDbType.VarChar, 4, ParameterDirection.Input, TextBox9.Text);
        SqlParameter parResult = AddOutputParameter("@Result", SqlDbType.VarChar, 100, ParameterDirection.Output);
        cmd.Parameters.Add(parEmployeeID);
        cmd.Parameters.Add(parLastName);
        cmd.Parameters.Add(parFirstName);
        cmd.Parameters.Add(parTitle);
        cmd.Parameters.Add(parPresentAddress);
        cmd.Parameters.Add(parCity);
        cmd.Parameters.Add(parPostalCode);
        cmd.Parameters.Add(parCountry);
        cmd.Parameters.Add(parExtension);
        cmd.Parameters.Add(parResult);
        cmd.ExecuteNonQuery();

        uiResultLabel.Visible = true;
        uiResultLabel.Text = "updated Successfully";
    }
}