20

我正在尝试通过调用存储过程将数据插入 SQL Server 数据库,但出现错误

*过程或函数“插入”需要参数“@Emp_no”,但未提供*

我的存储过程称为Insertion. 我已经彻底检查过了,没有丢失任何参数,我也使用标签检查过它。标签显示值,但我不知道为什么会出现错误。

我的代码是

    try
    {
        SqlCommand cmd = new SqlCommand();
        cmd.Parameters.Clear();
        cmd.CommandType = CommandType.StoredProcedure;
        cmd.CommandText = "Insertion";
        cmd.Connection = con;

        if (rdb_Male.Checked)
        {
            int @Emp_no = Convert.ToInt32(txtbx_Empno.Text);
            string @Emp_name = txtbx_Emp_Name.Text;
            double @phone = Convert.ToDouble(txtbx_Phone.Text);
            string @Email = txtbx_Email.Text;
            string @Password = txtbx_Pwd.Text;
            string @Gender = rdb_Male.Text;
            DateTime @Dob = Convert.ToDateTime(dob);
            string @Address = txtbx_Address.Text;
            string @Designation = txtbx_Designation.Text;
            string @Qualification = txtbx_Qual.Text;
            double @Experience = Convert.ToDouble(txtbx_Exp.Text);
            double @Salary = Convert.ToDouble(txtbx_Sal.Text);
            DateTime @Doj = Convert.ToDateTime(doj);
        }
        else if (rdb_Female.Checked)
        {
            int @Emp_no = Convert.ToInt32(txtbx_Empno.Text);
            string @Emp_name = txtbx_Emp_Name.Text;
            double @phone = Convert.ToDouble(txtbx_Phone.Text);
            string @Email = txtbx_Email.Text;
            string @Password = txtbx_Pwd.Text;
            string @Gender = rdb_Female.Text;
            DateTime @Dob = Convert.ToDateTime(dob);
            string @Address = txtbx_Address.Text;
            string @Designation = txtbx_Designation.Text;
            string @Qualification = txtbx_Qual.Text;
            double @Experience = Convert.ToDouble(txtbx_Exp.Text);
            double @Salary = Convert.ToDouble(txtbx_Sal.Text);
            DateTime @Doj = Convert.ToDateTime(doj);
        }

        if (con.State==ConnectionState.Closed)
            con.Open();

        LABEL.Text = txtbx_Empno.Text;

        cmd.ExecuteNonQuery();

        lbl_Errormsg.Visible = true;
        lbl_Errormsg.Text = "Record Inserted Successfully";

        con.Close();
    }

并且存储过程是

ALTER PROCEDURE dbo.Insertion
(
@Emp_no int,
@Emp_name varchar(30),
@phone numeric(10,0),
@Email varchar(30),
@Password varchar(10),
@Gender varchar(6),
@Dob date,
@Address varchar(100),
@Designation varchar(20),
@Qualification varchar(20),
@Experience numeric(4,2),
@Salary numeric(10,2),
@Doj date
)
AS
 Begin
   Insert into Register (Emp_no, Emp_name, phone, Email, Password, Gender, Dob, Address, Designation, Qualification, Experience, Salary, Doj)
   Values(@Emp_no, @Emp_name, @phone, @Email, @Password, @Gender, @Dob, @Address, @Designation, @Qualification, @Experience, @Salary, @Doj)
 End

请帮我。提前致谢。

4

9 回答 9

68

只是提醒一下,它可能会为某人节省大量的灵魂搜索时间。如果您已遵循此处的建议,例如使用 AddWithValue 来传递参数,并且您已经验证了所有内容,但仍然收到错误消息“未提供”,请检查您是否设置了命令对象的 CommandType 属性到 CommandType.StoredProcedure。

不设置这个属性会产生同样的信息,相信我!希望它可以帮助某人。

于 2016-07-04T12:23:36.823 回答
16

您需要使用SqlCommand.Parameters.AddWithValue

cmd.Parameters.AddWithValue("@ParameterName", value);

SqlCommand.Parameters.Add对于其他数据类型:

cmd.Parameters.Add("@ParameterName", SqlDbType.Int, 5);
cmd.Parameters["@ParameterName"].Value = value;

SqlCommand.Parameters.AddWithValueAdd替换了带字符串和对象参数的模棱两可的重载。有关详细信息,请参阅MSDN

于 2013-02-01T05:14:21.180 回答
8

对于其他人:我刚刚遇到同样的错误,因为我的参数之一为空。我们需要检查它,例如:

command.Parameters.AddWithValue("@phone", (object)phone?? DBNull.Value);
于 2017-07-14T12:59:35.660 回答
3

您的 Insertion 存储过程是预期的@Emp_no(以及大约 15 个其他参数)。不传递参数就不能调用存储过程。

看看这个网站以供参考:

http://msdn.microsoft.com/en-us/library/system.data.sqlclient.sqlparametercollection.addwithvalue.aspx?cs-save-lang=1&cs-lang=csharp#code-snippet-2

在您定义变量的任何地方,请Parameters.AddWithValue改用:

cmd.Parameters.AddWithValue("@Emp_no ", Convert.ToInt32(txtbx_Empno.Text));
于 2013-02-01T05:12:04.020 回答
2

你需要使用这个:

cmd.Parameters.AddWithValue("@Emp_no", @Emp_no);
cmd.Parameters.AddWithValue("@Emp_name", @Emp_name);
cmd.Parameters.AddWithValue("@phone", @phone);
cmd.Parameters.AddWithValue("@Email", @Email);
cmd.Parameters.AddWithValue("@Password", @Password);
cmd.Parameters.AddWithValue("@Gender", @Gender);
cmd.Parameters.AddWithValue("@Dob", @Dob);
cmd.Parameters.AddWithValue("@Address", @Address);
cmd.Parameters.AddWithValue("@Designation", @Designation);
cmd.Parameters.AddWithValue("@Experience", @Experience);
cmd.Parameters.AddWithValue("@Salary", @Salary);
cmd.Parameters.AddWithValue("@Doj", @Doj);

否则,它将为每个参数抛出该异常。

于 2013-02-01T05:09:21.380 回答
2

这是可以做到的

using (var cmd = new SqlCommand("STORED_PROCEDURE_NAME", SqlConnection))
{
     cmd.CommandType = CommandType.StoredProcedure;
     cmd.Parameters.AddWithValue("@PARAM_NAME", PARAM_VALUE);
}

请注意AddWithValue, 和CommandType.StoredProcedure两者都是必不可少的。

于 2018-06-19T18:51:12.757 回答
0

“只有一个 Add 方法已过时,该方法接受参数名称的字符串和值的对象。正如您所指出的,对于这种情况,您应该调用 AddWithValue。”

http://social.msdn.microsoft.com/Forums/en-US/15bb16a4-0cf1-4289-b677-3b9d98f09298/parametersaddwithvalue-output-parameter-in-adonet-2?forum=adodotnetdataproviders

并非所有 Parameter.Add 方法都已折旧。你想如何制作一个 OUTPUT 参数?您必须为此使用 Parameter.Add。

于 2014-02-15T16:14:06.553 回答
0

这些天仍然存在相同的错误消息,涉及多个问题 - 我的问题是将空值传递给参数。答案是像这样进行空检查:

parameter.Value = (object)yourParamVal ?? DBNULL.Value;
于 2019-04-12T12:52:21.633 回答
0

避免参数集为 DBNull.value 的没有值的参数

于 2020-07-07T02:30:33.603 回答