前提
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();