这个功能我实现过 这是 我的代码
后台代码:
using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Data.SqlClient;
public partial class Default5 : System.Web.UI.Page
{
SqlConnection sqlcon;
string strCon = "Data Source=(local);Database=北风贸易;Uid=sa;Pwd=sa";
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
bind();
}
}
protected void CheckBox2_CheckedChanged(object sender, EventArgs e)
{
for (int i = 0; i <= GridView1.Rows.Count - 1; i++)
{
CheckBox cbox = (CheckBox)GridView1.Rows[i].FindControl("CheckBox1");
if (CheckBox2.Checked == true)
{
cbox.Checked = true;
}
else
{
cbox.Checked = false;
}
}
}
protected void Button2_Click(object sender, EventArgs e)
{
sqlcon = new SqlConnection(strCon);
SqlCommand sqlcom;
for (int i = 0; i <= GridView1.Rows.Count - 1; i++)
{
CheckBox cbox = (CheckBox)GridView1.Rows[i].FindControl("CheckBox1");
if (cbox.Checked == true)
{
string sqlstr = "delete from where 身份证号码='" + GridView1.DataKeys[i].Value + "'";
sqlcom = new SqlCommand(sqlstr, sqlcon);
sqlcon.Open();
sqlcom.ExecuteNonQuery();
sqlcon.Close();
}
}
bind();
}
protected void Button1_Click(object sender, EventArgs e)
{
CheckBox2.Checked = false;
for (int i = 0; i <= GridView1.Rows.Count - 1; i++)
{
CheckBox cbox = (CheckBox)GridView1.Rows[i].FindControl("CheckBox1");
cbox.Checked = false;
}
}
public void bind()
{
string sqlstr = "select top 5 * from ";
sqlcon = new SqlConnection(strCon);
SqlDataAdapter myda = new SqlDataAdapter(sqlstr, sqlcon);
DataSet myds = new DataSet();
sqlcon.Open();
myda.Fill(myds, "tb_Member");
GridView1.DataSource = myds;
GridView1.DataKeyNames = new string[] { "身份证号码" };
GridView1.DataBind();
sqlcon.Close();
}
}
前台主要代码:
CellPadding="3" Font-Size="9pt" BackColor="White" BorderColor="#CCCCCC" BorderStyle="None" BorderWidth="1px">
Text="全选" />
在 checkbox 上设置一个onclick事件
点击的时候吧ID传入 一个input里 input runat
每个ID用符号分开 列如 1,2,3,4
然后删除的时候 拆分字符串
delete from table where id in (id1,id2,id3)
就是这样 明白了吧
//删除按钮的点击事件里这样写就可以
public void ButtonDelete(object sender,EventArgs e)
{
foreach (GridViewRow gr in GridView1.Rows)
{
if (gr.RowType == DataControlRowType.DataRow)
{
if (((CheckBox)gr.Cells[0].Controls[0]).Checked)
{
//这里写下你删除这行数据的代码
}
}
}
}
这个说起来话长了,删除时遍历gridview看哪行被选中,选中的话把ID取出来,用一条delete from table where id in (id1,id2,id3)这样的语句进行删除,编辑时把ID取出来 并把下面的那个显示出来不就得了
呵呵,这个网上的例子很多的,给你一个gridview技巧的网址,里面的例子都很好,基本上改一改就可以自己用了。
http://hi.baidu.com/fuyujian0420/blog/item/ed40c03dc738bcea3c6d9714.html