argumentnullexception未处理插入

时间:2014-06-25 22:54:01

标签: c# datagridview sql-server-ce

我正在尝试通过datagridview将数据插入数据库。到目前为止,我的代码检查表是否存在,如果不存在则创建新表,然后将数据复制到其中。我可以将数据复制到表中,一切正常。直到我收到错误 argumentnullexception未处理。数据被插入到表中,我可以查看表并查看数据。这是错误的描述:

  

参数化查询'插入[alalala_Thomas_Humphries_Quote]([项目名称],[项目描述],[零售价格],[供应商编号],[需要数量],[有货],[成本价格],[总成本] ],[总零售])值(@item,@ desc,@ retail,@ supplier,@ quantity,@ stock,@ cost,@ totalcost,@ lengthretail)'需要一个未提供的参数值。   参数名称:@item

这是我的代码:

private void insertData()
        {
            string tableName = quotenameTxt.Text + "_" + firstTxt.Text + "_" + surenameTxt.Text + "_Quote";

            SqlCeConnection con = new SqlCeConnection(@"Data Source=|DataDirectory|\LWADataBase.sdf");
            con.Open();
            SqlCeDataAdapter da = new SqlCeDataAdapter();

            for (int i = 0; i < dataGridView1.Rows.Count - 0; i++)
            {
                string query = "insert into [" + tableName + "]([Item Name], [Item Description], [Retail Price], [Supplier Number], [Quantity Required], [In stock], [Cost Price], [Total Cost],[Total Retail]) values (@item, @desc,@retail,@supplier,@quantity,@stock,@cost,@totalcost, @totalretail)";
                SqlCeCommand cmd = new SqlCeCommand(query, con);
                cmd.Parameters.Add(new SqlCeParameter("@item", dataGridView1.Rows[i].Cells[0].Value));
                cmd.Parameters.Add(new SqlCeParameter("@desc", dataGridView1.Rows[i].Cells[1].Value));
                cmd.Parameters.Add(new SqlCeParameter("@retail", dataGridView1.Rows[i].Cells[2].Value));
                cmd.Parameters.Add(new SqlCeParameter("@supplier", dataGridView1.Rows[i].Cells[3].Value));
                cmd.Parameters.Add(new SqlCeParameter("@quantity", dataGridView1.Rows[i].Cells[4].Value));
                cmd.Parameters.Add(new SqlCeParameter("@stock", dataGridView1.Rows[i].Cells[5].Value));
                cmd.Parameters.Add(new SqlCeParameter("@cost", dataGridView1.Rows[i].Cells[6].Value));
                cmd.Parameters.Add(new SqlCeParameter("@totalcost", dataGridView1.Rows[i].Cells[7].Value));
               cmd.Parameters.Add(new SqlCeParameter("@totalretail", dataGridView1.Rows[i].Cells[8].Value));
                da.InsertCommand = cmd;
                cmd.ExecuteNonQuery();
                MessageBox.Show("Quotation :" + tableName + " saved.", "Saved");
            }


        }  
  

我正在使用C#2010和SQLCe 3.5。

1 个答案:

答案 0 :(得分:0)

由于数据已插入表中,因此在将数据传递到数据库后,对象可能会出现转换问题。尝试将dataGridView1值转换为正确的类型,然后将它们作为参数传递:

cmd.Parameters.Add(new SqlCeParameter("@item", Convert.ToString(dataGridView1.Rows[i].Cells[0].Value)));

我希望这会有所帮助。

相关问题