1

下面是我编写的代码,其中我只在数据库中保存了第一行值,但是当我尝试保存多行值时,它给出了一个错误。我不知道如何在这段代码中使用循环以及在哪里使用循环一次在数据库中插入多行。

如何将 DataGridView 值保存到 SQL Server 数据库中?

private void button1_Click(object sender, EventArgs e)
{
    SqlCommand cmd = new SqlCommand("INSERT INTO datagrid (sr, name, email, tel_no) VALUES(@c1,@c2,@c3,@c4)", cs);
    {
        cmd.Parameters.Add(new SqlParameter("@C1", SqlDbType.VarChar));
        cmd.Parameters.Add(new SqlParameter("@C2", SqlDbType.VarChar));
        cmd.Parameters.Add(new SqlParameter("@C3", SqlDbType.VarChar));
        cmd.Parameters.Add(new SqlParameter("@C4", SqlDbType.VarChar));

        cs.Open();

        foreach (DataGridViewRow row in dataGridView1.Rows)
        {
            {
                if (!row.IsNewRow)
                {
                    cmd.Parameters["@C1"].Value = row.Cells[0].Value;
                    cmd.Parameters["@C2"].Value = row.Cells[1].Value;
                    cmd.Parameters["@C3"].Value = row.Cells[2].Value;
                    cmd.Parameters["@C4"].Value = row.Cells[3].Value;
                    cmd.ExecuteNonQuery();
                }
                cs.Close();
            }
        }
    }
}
4

4 回答 4

3

有一些您没有在原始问题中输入的信息会很高兴:

  1. cs很可能是 a SqlConnection,既然你说它可以插入一行,我猜它是一个全局(类级别)变量,并且是在其他地方创建的。我会做一些不同的事情(请参阅我的代码示例了解原因)。

  2. 你遇到了什么错误?根据问题描述,我敢打赌它是一个关闭的连接(因为您在 foreach 代码块的末尾关闭它,而您应该在 foreach 代码块之外关闭它)。

所以,话虽如此,这里有一些可能对你有用的东西:

private void button1_Click(object sender, EventArgs e)
{

    using (SqlConnection conn = new SqlConnection(connectionString))
    {

        cs.Open();

        foreach (DataGridViewRow row in dataGridView1.Rows)
        {

            if (!row.IsNewRow)
            {
                using (SqlCommand cmd = new SqlCommand("INSERT INTO datagrid (sr, name, email, tel_no) VALUES(@c1,@c2,@c3,@c4)", conn))
                {

                    cmd.Parameters.AddWithValue("@C1", row.Cells[0].Value);
                    cmd.Parameters.AddWithValue("@C2", row.Cells[1].Value);
                    cmd.Parameters.AddWithValue("@C3", row.Cells[2].Value);
                    cmd.Parameters.AddWithValue("@C4", row.Cells[3].Value);

                    cmd.ExecuteNonQuery();

                }
            }
        }
    }
}

在上面的示例中,我为and对象使用using了块。using 块可确保在退出 using 块时正确清理资源 - 这样您就不必担心何时调用之类的事情,因为该块会为您处理这些事情。SqlConnectionSqlCommandconn.Close()using

另外,我SqlConnection在方法中创建。在connectionString这种情况下,它将是一个字符串变量(在类级别,因此所有需要它的方法都可以访问它)保存连接字符串。

最后,我在 if 块中创建,只有当表达式计算为真SqlCommand时才会输入。!row.IsNewRow我不是 100% 确定您可以将值重新分配给现有命令的参数(很可能可以,但是...)

我还建议包括一些错误处理,以防插入出现问题。

希望这可以解决您遇到的问题/问题。如果没有,请提供更多详细信息,以便我们更好地为您提供帮助。快乐编码!

于 2013-06-25T06:57:46.200 回答
0
int ab;

 int PIrowss = dataGridView2.Rows.Count;

 for (ab = 0; ab < PIrowss; ab++)

 {

 PiCGetAutID();

 purchaeOrder.pcautoid = Catget;

 purchaeOrder.ponum = label119.Text;

 purchaeOrder.col1 = dataGridView2.Rows[ab].Cells[0].Value.ToString();

 purchaeOrder.col2 = dataGridView2.Rows[ab].Cells[1].Value.ToString();

 purchaeOrder.col3 = dataGridView2.Rows[ab].Cells[2].Value.ToString();

 purchaeOrder.col4 = dataGridView2.Rows[ab].Cells[3].Value.ToString();

  purchaeOrder.col5 = dataGridView2.Rows[ab].Cells[4].Value.ToString();


 purchaeOrder.POcSave();

}
于 2014-03-02T09:51:49.337 回答
0

问题是 cs 关闭的次数多于打开的次数。

您打开连接,插入,然后尝试关闭每次迭代。

您应该为每次迭代打开一个连接,或者您应该了解如何仅使用连接来完成所有操作。

于 2013-06-25T16:36:19.627 回答
-1
  private void button1_Click(object sender, EventArgs e)
        {                  
SqlConnection conn = new SqlConnection();
conn.Open();

SqlCommand comm = new SqlCommand();
comm.Connection = conn;

string sr = null;
string name = null;
string email = null;
string tel_no = null;


for (int i = 0; i <= this.DataGridView1.Rows.Count; i++) {
sr == this.DataGridView1.Rows(i).Cells(0).Value.ToString()
name == this.DataGridView1.Rows(i).Cells(1).Value.ToString()
email == this.DataGridView1.Rows(i).Cells(2).Value.ToString()
tel_no == this.DataGridView1.Rows(i).Cells(3).Value.ToString()

 comm.CommandText = "insert into mytable(name,age) values('" & name & "','" & age& "')"
   comm.ExecuteNonQuery()

conn.Close()


}

}

试试这个,看看。它应该工作

于 2013-06-25T06:34:19.937 回答