c#datagridview删除选中行,并删除SQL数据库中对应行

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c#datagridview删除选中行,并删除SQL数据库中对应行相关的知识,希望对你有一定的参考价值。

gridview可以和SQLdatasource 合用,在datasource里面设置好删除的sql语句,然后再gridview里面添加删除按钮,绑定到datasource的删除事件就好了,非常简便,另一种方法就是规矩的在aspx.c的页面上自己写整个删除事件追问

在datasource里面设置好删除的sql语句

怎么设置呢?

参考技术A 你datasource里面绑定的是什么呢?你可以在gridview中放一个隐藏列,比如id,然后选中行的时候你可以知道这个id。根据这个id删除。 参考技术B 这个先要查找被选中的行的主键的集合 然后传到后台sql删除 在重新绑定一下本回答被提问者采纳

DataGridView使用技巧四:删除行操作

一、无条件的删除行

默认时,DataGridView是允许用户进行行的删除操作,选中要删除的行,按Delete键可以删除,该操作没有任何提示(只是删除界面显示的数据,不会真实删除数据库中的数据)。如果设置DataGridView对象的AllowUserToDeleteRows属性为False,用户将被禁止删除行。

示例:禁止DataGridView删除行

1 this.dgv_PropDemo.AllowUserToDeleteRows = false;

但是,通过行的Remove或者RemoveAt还是可以删除行的。

示例:

1 //删除选中的第一行
2 this.dgv_PropDemo.Rows.Remove(this.dgv_PropDemo.SelectedRows[0]);

如果DataGridView绑定的是DataView的话,通过DataView.AllowDelete也可以控制行的删除。

二、删除行时的条件判断

用户在删除行的时候,将会引发DataGridView.UserDeletingRow事件。在这个事件里,可以判断条件并取消删除操作。(需要将AllowUserToDeleteRows设置为true,并且是使用键盘的delete键时才会触发该事件)。

UserDeletingRow:行被删除时触发。

UserDeletedRow:行被删除以后触发。执行顺序:先执行UserDeletingRow事件后执行UserDeletedRow事件。

示例:

 1 private void dgv_PropDemo_UserDeletingRow(object sender, DataGridViewRowCancelEventArgs e)
 2 {
 3        //删除前确认
 4        if (MessageBox.Show("确认要删除选中的行吗?", "删除确认", MessageBoxButtons.YesNo, MessageBoxIcon.Question) != DialogResult.Yes)
 5          {
 6              //如果不是Ok,则删除
 7              e.Cancel = true;
 8          }
 9 }
10 
11 private void dgv_PropDemo_UserDeletedRow(object sender, DataGridViewRowEventArgs e)
12 {
13         MessageBox.Show("该行已被删除");
14 }

三、删除选中的行

示例:

1 foreach (DataGridViewRow row in this.dgv_PropDemo.SelectedRows)
2 {
3       if (!row.IsNewRow)
4       {
5            this.dgv_PropDemo.Rows.Remove(row);
6       }
7 }

 

以上是关于c#datagridview删除选中行,并删除SQL数据库中对应行的主要内容,如果未能解决你的问题,请参考以下文章

datagridview中删除行并更新数据库

如何在datagridview中添加行,删除行,插入行???

怎么删除datagridview中选中的行啊

c#在datagridview中删除指定行并更新到数据库

c# 在datagridview 中 用鼠标选中一行删除并保存到数据库怎么实现?

c# datagridview 删除行