尝试插入我的数据失败

时间:2016-01-23 11:36:10

标签: c# mysql winforms runtime-error runtimeexception

我正在尝试将一些列表插入到我的数据库(Microsoft)中,但是我遇到了这个运行时错误

  

无法将参数值从List`1转换为Int32。

这是我的代码

  public void InsertInventory(DateTime _date, int _customer_Id,
                            int _employee_Id, List<int> _product_Id,
                            List<int> _amountSold,
                            List<int> _unitPrice, List<int> _totalPrice)
    {
        Connection_String = @"Data Source=MOSTAFA-PC;Initial Catalog="
                           + "Sales and Inventory System"
                           + ";Integrated Security=TrueData Source=MOSTAFA-PC;Initial Catalog="
                           + "Sales and Inventory System"
                           + ";Integrated Security=True;";

        Query = "insert into Inventory" +
                  "(Customer_Id,Employee_Id,Product_Id,[Date],[Amount Sold],[Unit Price],[Total Price])" +
                    "values (@customer_id,@Employee_id,@Product_id,@[Date],@[Amount_Sold],@[Unit_Price],@[Total_Price])";

        using (Con = new SqlConnection(Connection_String))
        using (Cmd = new SqlCommand(Query, Con))
        {
            Cmd.Parameters.Add("@customer_id", SqlDbType.Int);
            Cmd.Parameters.Add("@Employee_id", SqlDbType.Int);
            Cmd.Parameters.Add("@Product_id", SqlDbType.Int);
           //Cmd.Parameters.Add("@[Date]", SqlDbType.NVarChar);
            Cmd.Parameters.Add("@[Date]", SqlDbType.Date);
            Cmd.Parameters.Add("@[Amount_sold]", SqlDbType.Int);
            Cmd.Parameters.Add("@[Unit_Price]", SqlDbType.Decimal);
            Cmd.Parameters.Add("@Total_Price", SqlDbType.Decimal);

            Cmd.Connection = Con;
            Con.Open();

            int RecordToAdd = _product_Id.Count;
            for (int i = 0; i < RecordToAdd; i++)
            {
                Cmd.Parameters["@customer_id"].Value = _customer_Id;
                Cmd.Parameters["@Employee_id"].Value = _employee_Id;
                Cmd.Parameters["@Product_id"].Value = _product_Id;
                Cmd.Parameters["@[Date]"].Value = _date;
                Cmd.Parameters["@[Amount_sold]"].Value = _amountSold;
                Cmd.Parameters["@[Unit_Price]"].Value = _unitPrice;
                Cmd.Parameters["@Total_Price"].Value = _totalPrice;
                Cmd.ExecuteNonQuery();
            }

我搜索了网站,但我找不到任何与我的问题有用或类似的东西

我该怎么办?

2 个答案:

答案 0 :(得分:0)

更改&#34;列表&lt;&gt;&#34;在Inta或Integer的FUNCTION PARAMETERS中。

答案 1 :(得分:0)

改变这个:

android

对此:

core

注意在第二个块中我使用循环的迭代器来索引我每次插入的列表中的哪个项目。

编辑:此外,您构建的connection_string看起来不正确。您可能想要查看并更正任何错误