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がコントロールです。Textプロパティは、String値を保持します。

cmd.Parameters.Add(new SqlParameter("@EmpID", TextBox1.Text));
于 2012-07-20T17:05:35.370 に答える
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に変換する必要がある場合があります。null値も確認してください。

于 2012-07-20T17:25:55.237 に答える
0

なぜこのフォーマットを使わないのですか?

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