c#datagridview删除选中行,并删除SQL数据库中对应行
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c#datagridview删除选中行,并删除SQL数据库中对应行相关的知识,希望对你有一定的参考价值。
gridview可以和SQLdatasource 合用,在datasource里面设置好删除的sql语句,然后再gridview里面添加删除按钮,绑定到datasource的删除事件就好了,非常简便,另一种方法就是规矩的在aspx.c的页面上自己写整个删除事件追问在datasource里面设置好删除的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中添加行,删除行,插入行???