以下代码导致我的 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);
}
这是我执行它时发生的情况:
- 如果
stringVariable
为"插入"或"更新",则不会将 TextBox1 和 TextBox2 中的数据传递到过程。 - 如果
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 );