0

您好,我有一个用于注册页面的存储过程,但我需要 ADO.NET 从各种文本框中获取值。但是,我收到这样的错误:

“System.ArgumentException:不存在从对象类型 System.Web.UI.WebControls.TextBox 到已知托管提供程序本机类型的映射。”

public void InsertInfo()
    {
        String empdb = @"Data Source=USER-PC\SQLEXPRESS;Initial Catalog=EmployeeDB;Integrated Security=True";
        SqlConnection conn = new SqlConnection(empdb);
        SqlCommand cmd = new SqlCommand("bridge_Type", conn);
        cmd.CommandType = CommandType.StoredProcedure;


        try
        {
            conn.Open();
            cmd.Parameters.Add(new SqlParameter("@EmpID", TextBox1.Text));
            cmd.Parameters.Add(new SqlParameter("@Name", TextBox2.Text));
            cmd.Parameters.Add(new SqlParameter("@Mob2", TextBox3.Text));
            cmd.Parameters.Add(new SqlParameter("@Email", TextBox14.Text));
            cmd.Parameters.Add(new SqlParameter("@Emptype", dropdown1.SelectedValue));
            cmd.ExecuteNonQuery();
        }

        catch (System.Data.SqlClient.SqlException ex)
        {
            string msg = "Insert Error:";
            msg += ex.Message;
            throw new Exception(msg);

        }

        finally
        {
            if (conn != null)
            {
                conn.Close();
            }
        }

    }



    protected void Button1_Click(object sender, EventArgs e)
    {
        InsertInfo();
    }

然后我使用这种格式从控件中添加值:

cmd.Parameters.Add(new SqlParameter("@EmpID", SqlDbType.Int));
cmd.Parameters("@EmpID").Value = TextBox1.Text;

我收到以下错误:

Its showing errors for these kind of codes by appearing red line under 'Parameters'.

Non-invocable member 'System.Data.SqlClient.SqlCommand.Parameters' cannot be used like a method.
4

3 回答 3

2

试试TextBox1.Text,TextBox就是Control。Text 属性保存字符串值。

cmd.Parameters.Add(new SqlParameter("@EmpID", TextBox1.Text));
于 2012-07-20T17:05:35.370 回答
0

你为什么不使用这种格式?

         cmd.Parameters.Add("@parameter", SqlDBType , size).value = TextBox1.Text
于 2012-07-20T17:40:24.780 回答
0

试试这个代码。

try
{
  string empdb = @"Data Source=USER-PC\SQLEXPRESS;Initial Catalog=EmployeeDB;Integrated Security=True";
  using (var conn = new SqlConnection(connString))
  {
    using (var cmd = new SqlCommand("bridge_Type",conn))
    {           
        cmd.CommandType = CommandType.StoredProcedure;           
        cmd.Parameters.AddWithValue("@EmpID",TextBox1.Text);
        cmd.Parameters.AddWithValue("@Name", TextBox2.Text);    
        cmd.Parameters.AddWithValue("@Mob2", TextBox3.Text); 
        cmd.Parameters.AddWithValue("@Email", TextBox14.Text); 
        cmd.Parameters.AddWithValue("@EmpType",dropdown1.SelectedValue); 
        conn.Open();
        cmd.ExecuteNonQuery();           
    }
  }
}
catch(Exception ex)
{
   string msg = "Insert Error:"+ ex.Message;
   throw new Exception(msg);
}

确保您转换为与存储过程中的参数类型相同的类型(例如:如果 EmpID 的参数类型是 int,您可能需要将TextBox1.Text值转换为 int。还要检查空值。

于 2012-07-20T17:25:55.237 回答