我使用C#在Windows窗体中DataGridView
。
数据显示成功,更新也成功完成。
但问题在于插入问题。当我尝试使用迭代将多个数据插入数据库时,它会将13次存储到数据库中,因为数据网格最初显示来自数据库的13条记录。我的意思是它多次将新行存储(datagridview行计数)到数据库中。
假设我想将两行保存到数据库中,但它将第一行存储到数据库中13次(datagridview行的总数)。
请检查我在哪里做错了
注意:我想使用单个datagridview来显示,更新,插入和删除数据库中的数据。我有按钮,我想通过它开始将所有新行插入数据库。
我的代码在
下面string connection = System.Configuration.ConfigurationManager.ConnectionStrings["AuzineConnection"].ConnectionString;
using (SqlConnection sqlconn = new SqlConnection(connection))
{
sqlconn.Open();
foreach (DataGridViewRow row in dataGridView1.Rows)
{
if (row.IsNewRow)
{
using (SqlCommand sqlcomm = sqlconn.CreateCommand())
{
//sqlcomm.CommandText = "Insert into QF (profileID, UserNameLogInName, UserFullName,Email, forumtitle, subtitle, subjecttitle ,noreply, noview , qtags ,Question ,Questiondetails ,questionstatus, qdate, Status ,todate) values(@status)";
sqlcomm.CommandText = "Insert into QF (UserNameLogInName,Status ) values(@UserNameLogInName,@status)";
try
{
sqlcomm.Parameters.AddWithValue("UserNameLogInName", dataGridView1.CurrentRow.Cells["UserNameLogInName"].Value.ToString());
sqlcomm.Parameters.AddWithValue("Status", dataGridView1.CurrentRow.Cells["Status"].Value.ToString());
sqlcomm.ExecuteNonQuery();
//MessageBox.Show(dataGridView1.Rows[Convert.ToInt32(RecordIndexNumber.Text)].Cells[Convert.ToInt32(ColInexNum.Text)].Value.ToString());
}
catch (Exception ex)
{
btnInsert.Text = ex.Message.ToString();
}
}
}
}
}
我已经尝试了if (!row.IsNewRow)
并且它只存储了一行。没有它会将多个不需要的时间存储到数据库中。
我也使用了for (int i = 0; i < dataGridView1.Rows.Count - 1; i++)
,但同样的问题是存储了一次或多次。
我只是想在按钮点击时插入用户生成的新行。
答案 0 :(得分:0)
试试这个:
sqlcomm.Parameters.AddWithValue("UserNameLogInName", row.Cells["UserNameLogInName"].Value.ToString());
sqlcomm.Parameters.AddWithValue("Status", row.Cells["Status"].Value.ToString());