m0_62982675 2023-03-11 10:36 采纳率: 50%
浏览 23
已结题

点击新增按键datagridview新增一行

怎样点击新增按键在datagridview中新增一行,并且可以在其中填入新的数据,保存后同步到数据库。

  • 写回答

1条回答 默认 最新

  • 嗷呜大嘴狼 2023-03-11 10:39
    关注

    在 WinForm 应用程序中,可以使用 DataGridView 控件来显示和编辑数据。可以通过以下步骤来实现在 DataGridView 中点击新增按钮添加新行并保存到数据库中的功能:

    添加 DataGridView 控件和新增按钮到窗体上。可以通过 Visual Studio 的设计器来实现。

    为新增按钮添加 Click 事件的处理函数。在事件处理函数中,可以通过 DataGridView 的 Rows 属性添加新行。

    private void btnAdd_Click(object sender, EventArgs e)
    {
        dataGridView.Rows.Add();
    }
    
    
    

    在 DataGridView 中,可以使用 CellEndEdit 事件来捕获单元格编辑结束的事件,这时可以将修改后的数据同步到数据库中。需要注意的是,DataGridView 中的新增行默认是空行,需要手动判断并过滤掉。

    private void dataGridView_CellEndEdit(object sender, DataGridViewCellEventArgs e)
    {
        // 只处理非新增行
        if (e.RowIndex >= dataGridView.Rows.Count - 1)
        {
            return;
        }
    
        // 获取修改后的数据
        int id = Convert.ToInt32(dataGridView.Rows[e.RowIndex].Cells["ID"].Value);
        string name = dataGridView.Rows[e.RowIndex].Cells["Name"].Value.ToString();
        // ...
    
        // 更新数据库
        SqlConnection conn = new SqlConnection("server=localhost;database=mydb;uid=myuser;pwd=mypassword;");
        conn.Open();
        SqlCommand cmd = new SqlCommand("UPDATE mytable SET Name=@Name WHERE ID=@ID", conn);
        cmd.Parameters.AddWithValue("@ID", id);
        cmd.Parameters.AddWithValue("@Name", name);
        // ...
        cmd.ExecuteNonQuery();
        conn.Close();
    }
    
    
    

    完整的示例代码如下:

    using System;
    using System.Data.SqlClient;
    using System.Windows.Forms;
    
    namespace DataGridViewExample
    {
        public partial class Form1 : Form
        {
            public Form1()
            {
                InitializeComponent();
            }
    
            private void Form1_Load(object sender, EventArgs e)
            {
                // 初始化 DataGridView 数据
                SqlConnection conn = new SqlConnection("server=localhost;database=mydb;uid=myuser;pwd=mypassword;");
                conn.Open();
                SqlCommand cmd = new SqlCommand("SELECT * FROM mytable", conn);
                SqlDataReader reader = cmd.ExecuteReader();
                while (reader.Read())
                {
                    dataGridView.Rows.Add(reader["ID"], reader["Name"], reader["Age"]);
                }
                conn.Close();
            }
    
            private void btnAdd_Click(object sender, EventArgs e)
            {
                dataGridView.Rows.Add();
            }
    
            private void dataGridView_CellEndEdit(object sender, DataGridViewCellEventArgs e)
            {
                // 只处理非新增行
                if (e.RowIndex >= dataGridView.Rows.Count - 1)
                {
                    return;
                }
    
                // 获取修改后的数据
                int id = Convert.ToInt32(dataGridView.Rows[e.RowIndex].Cells["ID"].Value);
                string name = dataGridView.Rows[e.RowIndex].Cells["Name"].Value.ToString();
                int age = Convert.ToInt32(dataGridView.Rows[e.RowIndex].Cells["Age"].Value);
    
                // 更新数据库
                SqlConnection conn = new SqlConnection("server=localhost;database=mydb;uid=myuser;pwd=mypassword;");
                conn.Open();
                SqlCommand cmd = new SqlCommand("UPDATE mytable SET Name=@Name, Age=@Age WHERE ID=@ID", conn);
                cmd.Parameters.AddWithValue("@ID", id);
                cmd.Parameters.AddWithValue("@Name", name);
                cmd.Parameters.AddWithValue("@Age", age);
                cmd.ExecuteNonQuery();
                conn.Close();
            }
        }
    }
    
    
    

    答案出自c# https://www.wodianping.com/

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 3月19日
  • 已采纳回答 3月11日
  • 创建了问题 3月11日

悬赏问题

  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)
  • ¥15 AIC3204的示例代码有吗,想用AIC3204测量血氧,找不到相关的代码。