尝试在 Windows 窗体中使用 SQL 存储过程



以下代码导致我的 Windows 窗体应用程序中出现问题:

SqlConnection cnnDB = new SqlConnection(<connection string>);
try
{
    SqlCommand cmd = cnnDB.CreateCommand();
    cmd.CommandType = CommandType.StoredProcedure;
    cmd.CommandText = "sp_ProcName";
    cmd.Parameters.AddWithValue("@int1", ComboBox1.SelectedValue);
    cmd.Parameters.AddWithValue("@int2", ComboBox2.SelectedValue);
    cmd.Parameters.AddWithValue("@int3", ComboBox3.SelectedValue);
    cmd.Parameters.AddWithValue("@int4", ComboBox4.SelectedValue);
    cmd.Parameters.AddWithValue("@varchar1", TextBox1.Text);
    cmd.Parameters.AddWithValue("@varchar2", TextBox2.Text);
    cmd.Parameters.AddWithValue("@varchar3", ComboBox5.SelectedValue);
    cmd.Parameters.AddWithValue("@varchar4", stringVariable);
    cnnDB.Open();
    cmd.ExecuteNonQuery();
    cnnDB.Close();
}
catch (Exception ex)
{
    MessageBox.Show(ex.Message);
}

这是我执行它时发生的情况:

  1. 如果stringVariable为"插入"或"更新",则不会将 TextBox1 和 TextBox2 中的数据传递到过程。
  2. 如果stringVariable是"删除",则出现错误"过程或函数'sp_ProcName'需要参数'@varchar3',但未提供"。

代码有问题吗?

编辑:根据@Steve和@MethodMan的要求,下面是SQL Server中的存储过程。

ALTER PROCEDURE [dbo].[sp_ProcName]
(
      @int1 int,
      @int2 int,
      @int3 int,
      @int4 int,
      @varchar1 varchar(7),
      @varchar2 varchar(6),
      @varchar3 nvarchar(10),
      @varchar4 nvarchar(10) = ''
)
AS
BEGIN
     SET NOCOUNT ON;
     IF @varchar4 = 'Insert'
     BEGIN
          INSERT INTO Table1(int1,int2,int3,int4,varchar1,varchar2,varchar3)
          VALUES(@int1,@int2,@int3,@int4,@varchar1,@varchar2,@varchar3)
     END
     IF @varchar4 = 'Update'
     BEGIN
          UPDATE Table1
               SET int1=@int1, int2=@int2, int3=@int3, int4=@int4, varchar1=@varchar1, varchar2=@varchar2, varchar3=@varchar3
          WHERE varchar1 = @varchar1
     END
     IF @varchar4 = 'Delete'
     BEGIN
          DELETE FROM Table1
          WHERE varchar1 = @varchar1
     END

好吧,经过仔细检查,我发现存储过程中的更新部分是"坏蛋"。我需要找到其他方法。也删除部分。

附言对不起,长篇大论。

需要使用 DBNull.Value 而不是null或为可能缺少的存储过程参数分配默认值

方法 1 :

CREATE PROCEDURE [dbo].[problemParam] 
    // Other parameters go here then
    @varchar1 NVARCHAR(50) = null, 
    @varchar1 NVARCHAR(50) = null,
    @varchar1 NVARCHAR(50) = null, 
AS  
BEGIN
  -- Procedure Logic go here
END

方法2:

object param1 = DBNull.Value;
object param2 = DBNull.Value;
object param3 = DBNull.Value;
if(!String.IsNullOrEmpty(TextBox1.Text))
    param1 = TextBox1.Text;
if(!String.IsNullOrEmpty(TextBox2.Text))
    param2 = TextBox2.Text;
if(ComboBox5.SelectedValue != null)
    param3 = TextBox1.Text;
cmd.Parameters.AddWithValue("@varchar1", param1 );
cmd.Parameters.AddWithValue("@varchar2", param2 );
cmd.Parameters.AddWithValue("@varchar3", param3 );

最新更新