在gridview中实现删除选定行 删除键在gridview外

2025-01-04 14:00:06
推荐回答(5个)
回答1:

这个功能我实现过  这是 我的代码

后台代码:

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="全选" />

                    

                    

回答2:

在 checkbox 上设置一个onclick事件

点击的时候吧ID传入 一个input里 input runat

每个ID用符号分开 列如 1,2,3,4

然后删除的时候 拆分字符串

delete from table where id in (id1,id2,id3)

就是这样 明白了吧

回答3:

//删除按钮的点击事件里这样写就可以
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)
{
//这里写下你删除这行数据的代码
}
}
}
}

回答4:

这个说起来话长了,删除时遍历gridview看哪行被选中,选中的话把ID取出来,用一条delete from table where id in (id1,id2,id3)这样的语句进行删除,编辑时把ID取出来 并把下面的那个显示出来不就得了

回答5:

呵呵,这个网上的例子很多的,给你一个gridview技巧的网址,里面的例子都很好,基本上改一改就可以自己用了。
http://hi.baidu.com/fuyujian0420/blog/item/ed40c03dc738bcea3c6d9714.html