C#如何在DataGridView里面添加一列复选框进行批量删除

前提

1,我的DataGridView名字是dgvwell

2,我想在第五列加入复选框以实现批量删除。

3,点击批量删除按钮(button1),再点击确定删除按钮(button3)来实现。

效果

在这里插入图片描述

代码

点击批量删除按钮触发的事件:

 //首先要判断是否为空表
 //如果是空表要给出提示
            if (dgvWell.Rows.Count < 1)
            {
                MessageBox.Show(this, "提示", "目前不存在数据", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
//如果不是空表
            else
            {        
            //先new一个checkcell,给定标题名字        
                    checkCell = new DataGridViewCheckBoxColumn();
                    checkCell.Name = "批量删除";
                    //插入到第五列
                    dgvWell.Columns.Insert(5, checkCell);
                    //调整checkcell的宽度                  
                    dgvWell.Columns[5].AutoSizeMode = DataGridViewAutoSizeColumnMode.AllCells;
                    dgvWell.Columns[5].Visible = true;
                    //这时候设置批量删除按钮不能工作,确定删除按钮可以被看到
                    button3.Visible = true;
                    button1.Enabled = false;
                
            }

点击确定删除按钮触发的事件:

 //询问是否删除
            DialogResult dr = MessageBox.Show(this, "是否确认删除选中的数据?", "询问", MessageBoxButtons.YesNo, MessageBoxIcon.Question);
            //如果点击确定
            if (dr == DialogResult.Yes)
            {
                //判断表是否为空
                if (dgvWell.Rows.Count < 1)
                {
                    MessageBox.Show(this, "错误", "目前不存在数据", MessageBoxButtons.OK, MessageBoxIcon.Error);
                }
                else
                {
                    Models.DBEntities db = new Models.DBEntities();
                    //遍历dgv的每一行
                    for (int i = 0; i < dgvWell.Rows.Count; i++)
                    {
                    //判断是否勾选了复选框
                        if ((bool)dgvWell.Rows[i].Cells[5].EditedFormattedValue == true)
                        {
                        //设置当前选中的行
                            Common.Variables.CurrentWellID = Convert.ToInt32(dgvWell.Rows[i].Cells[0].Value);
                            var well_check = db.WellInfoes.Find(Common.Variables.CurrentWellID);
                            if (well_check != null)
                            {
                            //数据库中移除该行
                                db.WellInfoes.Remove(well_check);                           
                            }
                        }
                    }
                    //数据库中保存数据
                    db.SaveChanges();
                    checkCell.Visible = false;
                    button3.Visible = false;
                    button1.Enabled = true;
                }
            }
     //这里应该写一个更新该界面的代码,此处省略。。

提示

1,其实这个代码在某些情况下是可能存在问题的,比如要考虑到我们其实一直在第五列加入复选框,点一次批量删除按钮就一直加。但是我们把之前的隐藏了,所以表面上看不出来。
2,在DataGridView已经和数据库绑定的情况下,要想真的点确定删除按钮,在删除该列之后再重新new一列的checkcell,我这边出了点问题,于是我想了个避开的办法,也就是在最后更新该界面我省略了的地方。
比如我是点击button这个按钮进入的该界面,我先Dispose这个界面,再模拟点击这个按钮:

this.Dispose();//先删除该界面再模拟点击一次
button.PerformClick();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值