我正在尝试通过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。
答案 0 :(得分:0)
由于数据已插入表中,因此在将数据传递到数据库后,对象可能会出现转换问题。尝试将dataGridView1值转换为正确的类型,然后将它们作为参数传递:
cmd.Parameters.Add(new SqlCeParameter("@item", Convert.ToString(dataGridView1.Rows[i].Cells[0].Value)));
我希望这会有所帮助。