问题:全选后删除没有问题,DataGridViewCheckBoxColumn

来源:互联网 发布:centos 源码安装lnmp 编辑:程序博客网 时间:2024/04/29 01:23
  问题:全选后删除没有问题,但是选择了其中几条后,不能将选中的这些记录都删除掉,总是有那么几条删不掉?
请大家帮忙看看我的代码,帮忙纠正,有更好的方法请给出关键代码,谢谢!

datagridview设计如下:第1列是DataGridViewCheckBoxColumn列,其他列是DataGridViewTextBoxColumn列

//代码如下:
using   System;
using   System.Collections.Generic;
using   System.ComponentModel;
using   System.Data;
using   System.Data.SqlClient;
using   System.Drawing;
using   System.Text;
using   System.Windows.Forms;

namespace   test
{
        public   partial   class   Form1   :   Form
        {
                public   Form1()
                {
                        InitializeComponent();
                }
                LinkDB   linkdb   =   new   LinkDB();
                string   strSelectAll   =   "select   *   from   tb1 ";
                string   strTable   =   "tb1 ";
                DataSet   ds   =   new   DataSet();
                private   void   Form1_Load(object   sender,   EventArgs   e)
                {
                        dataGridView1.AutoGenerateColumns   =   false;
                        dataGridView1.AllowUserToAddRows   =   false;
                        dataGridView1.AlternatingRowsDefaultCellStyle.BackColor   =   Color.Azure;
                        ds   =   linkdb.QueryDB(strSelectAll,   strTable);
                        dataGridView1.DataSource   =   ds;
                        dataGridView1.DataMember   =   strTable;
                }

                bool   blIsSelectAll   =   false;
//全选
                private   void   btnSelectAll_Click(object   sender,   EventArgs   e)
                {
                        foreach   (DataGridViewRow   dr   in   dataGridView1.Rows)
                        {
                                ((DataGridViewCheckBoxCell)dr.Cells[0]).Value   =   true;
                        }
                        blIsSelectAll   =   true;
                        return;
                }

//取消全选
                private   void   btnCancelAll_Click(object   sender,   EventArgs   e)
                {
                        foreach   (DataGridViewRow   dr   in   dataGridView1.Rows)
                        {
                                ((DataGridViewCheckBoxCell)dr.Cells[0]).Value   =   false;
                        }
                        blIsSelectAll   =   false;
                        return;
                }

//删除
                private   void   btnDelete_Click(object   sender,   EventArgs   e)
                {
                        try
                        {
                                if   (dataGridView1.Rows.Count   >   0)
                                {
                                        if   (blIsSelectAll)   //全选:进行批量删除
                                        {
                                                for   (int   rowIndex   =   0;   rowIndex   <   ds.Tables[strTable].Rows.Count;   rowIndex++)
                                                {
                                                        ds.Tables[strTable].Rows[rowIndex].Delete();//逻辑性删除(从数据集ds中删除)
                                                        //物理性删除(从DB中删除)
                                                }
                                        }
                                        else   //删除选中了记录
                                        {
                                                for   (int   j   =   0;   j   <   dataGridView1.Rows.Count;   j++)
                                                {
                                                        if   (Convert.ToBoolean(dataGridView1[0,   j].EditedFormattedValue.ToString()))
                                                        {
                                                                ds.Tables[strTable].Rows[j].Delete();//逻辑性删除
//物理性删除
                                                        }
                                                }
                                        }
                                }
                        }
                        catch   (Exception   ex)
                        {
                                MessageBox.Show(ex.Message);
                        }
                }

                private   void   dataGridView1_CellValueChanged(object   sender,   DataGridViewCellEventArgs   e)
                {
                        blIsSelectAll   =   false;
                }
        }
}     50  修改 删除 举报 引用 回复
进入用户个人空间
加为好友
发送私信
在线聊天
  • noky
  • 等级:
发表于:2007-04-13 13:44:301楼 得分:0 哈哈,知道你的问题处在那里了,你在用DataGridView等等控件做删除的时候都去循环选中的行或者列进行删除!那你其不知,在循环完成一次后,你的dataGridView1.Rows.Count已经给变了,你在循环删除的时候当然删除不干净了,应为你的循环量已经便利。
解决方法
首先缓存你所选择的行,比如把选择的行存在List <DataGridViewRow>   中,然后循环List进行删除。不要循环DataGridView.Rows.Count进行删除
  修改 删除 举报 引用 回复
进入用户个人空间
加为好友
发送私信
在线聊天
  • noky
  • 等级:
发表于:2007-04-13 13:47:162楼 得分:0 这是一个普遍存在的问题,这种控件有ListBox,DataGridView,DataGrid等等一些控件,不要在用.Count循环进行删除。   修改 删除 举报 引用 回复
进入用户个人空间
加为好友
发送私信
在线聊天
  • zhengye6910
  • 等级:
发表于:2007-04-13 13:48:593楼 得分:0 noky:能不能给出代码看看啊   修改 删除 举报 引用 回复
进入用户个人空间
加为好友
发送私信
在线聊天
  • noky
  • 等级:
发表于:2007-04-13 14:11:024楼 得分:45 for   (int   j   =   0;   j   <   dataGridView1.Rows.Count;   j++)
{
      if   (Convert.ToBoolean(dataGridView1[0,   j].EditedFormattedValue.ToString()))
      {
              ds.Tables[strTable].Rows[j].Delete();//逻辑性删除
//物理性删除
        }
}
改成:
  List <DataGridViewRow>   tmpList   =   new   List <DataGridViewRow> ();
                                for   (int   j   =   0;   j   <   dataGridView1.Rows.Count;   j++)
                                {
                                        if   (Convert.ToBoolean(dataGridView1[0,   j].EditedFormattedValue.ToString()))
{
                                                tmpList.Add(ds.Tables[strTable].Rows[j]);
                                        }
                                }
                                for   (int   i   =   0;   i   <   tmpList.Count;   i++)
                                {
                                        dataGridView1.Rows.Remove(tmpList[i]);
                                }
                                tmpList   ==   null;   修改 删除 举报 引用 回复
进入用户个人空间
加为好友
发送私信
在线聊天
  • sbqcel
  • 等级:
发表于:2007-04-13 14:15:515楼 得分:3 for   (int   rowIndex   =   0;   rowIndex   <   ds.Tables[strTable].Rows.Count;   rowIndex++)
                                                {
                                                        ds.Tables[strTable].Rows[rowIndex].Delete();//逻辑性删除(从数据集ds中删除)
                                                        //物理性删除(从DB中删除)
                                                }

to:

for   (int   rowIndex   =   ds.Tables[strTable].Rows.Count;   rowIndex   > =   0;   rowIndex--)
                                                {
                                                        ds.Tables[strTable].Rows[rowIndex].Delete();//逻辑性删除(从数据集ds中删除)
                                                        //物理性删除(从DB中删除)
                                                }
  修改 删除 举报 引用 回复
进入用户个人空间
加为好友
发送私信
在线聊天
  • zhangci226
  • 等级:
发表于:2007-04-13 14:42:356楼 得分:2 删除记录的时候不要从选择记录的第一条开始,因为第一条删除後,后面的index都不对了

所以应该从选择记录的最後一条开始删除   修改 删除 举报 引用 回复
进入用户个人空间
加为好友
发送私信
在线聊天
  • LoveCleverDog
  • 等级:
发表于:2007-04-13 14:48:267楼 得分:0 呵呵   以前也遇到过这个问题     帮   UP   下   修改 删除 举报 引用 回复
进入用户个人空间
加为好友
发送私信
在线聊天
  • liujiwe79
  • 等级:
发表于:2007-04-13 14:54:568楼 得分:0 删除记录的时候不要从选择记录的第一条开始,因为第一条删除后
后面的index都不对了,所以应该从选择记录的最后一条开始删除
  修改 删除 举报 引用 回复
进入用户个人空间
加为好友
发送私信
在线聊天
  • zhengye6910
  • 等级:
发表于:2007-04-13 14:55:199楼 得分:0 noky:你的代码还有点问题啊,我按你那样写了,调试时还有错误!   修改 删除 举报 引用 回复
进入用户个人空间
加为好友
发送私信
在线聊天
  • zhengye6910
  • 等级:
发表于:2007-04-13 14:58:4010楼 得分:0 调试好了,谢谢noky!
tmpList=null   修改 删除 举报 引用 回复
进入用户个人空间
加为好友
发送私信
在线聊天
  • zhengye6910
  • 等级:
发表于:2007-04-13 14:59:5011楼 得分:0 List <DataGridViewRow>   tmpList   =   new   List <DataGridViewRow> ();
                                                for   (int   j   =   0;   j   <   dataGridView1.Rows.Count;   j++)
                                                {
                                                        if   (Convert.ToBoolean(dataGridView1[0,   j].EditedFormattedValue.ToString()))
                                                        {
                                                                tmpList.Add(dataGridView1.Rows[j]);
                                                        }
                                                }
                                                for   (int   i   =   0;   i   <   tmpList.Count;   i++)
                                                {
                                                        dataGridView1.Rows.Remove(tmpList[i]);
                                                }
                                                tmpList   =   null;
原创粉丝点击