日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

在GridView中的批量删除!

發布時間:2025/3/21 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 在GridView中的批量删除! 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1.通過GridView的屬性:DataKeyNames來獲取主鍵;

2.遍歷數據行,獲取選中的CheckBox 所屬的行的主鍵.(有點繞口...慢慢看...)

3.拼接SQL語句; Delete 表名 where id in(XX,XX,XX);

?

Default.aspx頁完整代碼:

View Code <%@?Page?Language="C#"?AutoEventWireup="true"?CodeBehind="Default.aspx.cs"?Inherits="WebApplication1.Default"?%>

<!DOCTYPE?html?PUBLIC?"-//W3C//DTD?XHTML?1.0?Transitional//EN"?"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html?xmlns="http://www.w3.org/1999/xhtml">
<head?runat="server">
????
<title></title>
</head>
<body>
????
<form?id="form1"?runat="server">
????
<div>
????????
<br?/>
????????
<asp:Button?ID="btnDelete"?runat="server"?Text="刪除選中項"?OnClick="btnDelete_Click"
????????????Style
="height:?21px"?/>
????????
<br?/>
????????
<br?/>
???????
<%--?通過給GridView1添加屬性:DataKeyNames來獲取主鍵;--%>
????????
<asp:GridView?ID="GridView1"?runat="server"?AutoGenerateColumns="false"?
????????????Width
="881px"?DataKeyNames="id">
????????????
<Columns>
????????????????
<asp:BoundField?DataField="id"?HeaderText="編號"?/>
????????????????
<asp:BoundField?DataField="uname"?HeaderText="名稱"?/>
????????????????
<asp:TemplateField?HeaderText="選擇">
????????????????????
<ItemTemplate>
????????????????????????
<asp:CheckBox?ID="cbxId"?runat="Server"?/>
????????????????????
</ItemTemplate>
????????????????
</asp:TemplateField>
????????????
</Columns>
????????
</asp:GridView>
????
</div>
????
</form>
</body>
</html>

?

Default.aspx.cs完整代碼:

View Code using?System;
using?System.Web.UI.WebControls;
using?System.Data;

namespace?WebApplication1
{
????
public?partial?class?Default?:?System.Web.UI.Page
????{
????????
protected?void?Page_Load(object?sender,?EventArgs?e)
????????{
????????????
if?(!this.IsPostBack)
????????????{
????????????????GetData();
????????????}
????????}

????????
//綁定數據
????????protected?void?GetData()
????????{
????????????
string?sql?=?"select?*?from?userinfo";
????????????GridView1.DataSource?
=?SQLHelper.GetDateSet(sql,?CommandType.Text);
????????????GridView1.DataBind();
????????}

????????
protected?void?btnDelete_Click(object?sender,?EventArgs?e)
????????{
????????????
//sqlText用于拼接SQL語句;
????????????string?sqlText?=?"(";
????????????
foreach?(GridViewRow?objGVR?in?this.GridView1.Rows)
????????????{
????????????????
//判斷當前行是否為數據行;
????????????????if?(objGVR.RowType?==?DataControlRowType.DataRow)
????????????????{
????????????????????CheckBox?objCB?
=?objGVR.FindControl("cbxId")?as?CheckBox;

????????????????????
if?(objCB.Checked)
????????????????????{
????????????????????????
//獲取選中行的主鍵;
????????????????????????sqlText?+=?this.GridView1.DataKeys[objGVR.RowIndex]["id"].ToString()?+?",";
????????????????????}
????????????????}
????????????}

????????????
//去掉最后的逗號,并且加上右括號?,如果不去掉最后一個逗號變會成這樣(1,2,3,4,5,6,)
????????????sqlText?=?sqlText.Substring(0,?sqlText.Length?-?1)?+?")";

????????????sqlText?
=?"delete?userinfo?where?id?in"?+?sqlText;

????????????Response.Write(
"拼接后的SQL語句為:"?+?sqlText);
????????????
//執行刪除語句?
????????????int?delCount?=?Convert.ToInt32(SQLHelper.ExecuteNonQuery(sqlText,?CommandType.Text));

????????????Response.Write(
"共刪除數據:"?+?delCount?+?"");

????????????
this.GetData();


????????}
????}
}

?

如需全選功能請參見:http://www.cnblogs.com/zhuiyi/archive/2011/06/27/2091738.html

總結

以上是生活随笔為你收集整理的在GridView中的批量删除!的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。