winform代码:关联窗体数据更新,删除dataGridview中选中的一行或多行

一、关联窗体数据更新

关联窗体数据修改时,如果一个为总体数据显示窗体A,另一个为详细修改窗体B,从A进入B,在B中对数据进行修改,然后返回A,这时A窗体的数据需要更新。

我采用最简单的方法,首先保证每个窗体只有一个(网上代码很多),每次激活窗体时就重新载入数据,从A进入B的代码如下:

#region 激活或创建用户管理层面
            bool isExit = false;
            foreach (Form childFrm in this.MdiParent.MdiChildren)
            {
                //用子窗体的Name进行判断,如果已经存在则将他激活
                if (childFrm.Name == "Form_UserManage")
                {
                    if (childFrm.WindowState == FormWindowState.Minimized)
                        childFrm.WindowState = FormWindowState.Normal;
                    childFrm.Activate();
                    isExit = true;
                }
            }
            if (isExit == false)
            {
                // 如果该窗体不存在则新生成一个库存查询窗体
                Form_UserManage newFrm = new Form_UserManage();
                newFrm.MdiParent = this.MdiParent;
                newFrm.Show();
            }
            this.Close();
            #endregion

也可以让B成为模式窗体,比较简单。上面A和B是独立的两个窗体,都在同一级菜单下时使用较好。  

一、删除dataGridview中选中的一行或多行

参考博文:http://blog.sina.com.cn/s/blog_8b94db9c01015yim.html

DialogResult RSS = MessageBox.Show(this,"确定要删除选中行数据码?","提示",MessageBoxButtons.YesNo,MessageBoxIcon.Warning);
switch(RSS)
{
case DialogResult.Yes:
for (int i = this.dataGridView1.SelectedRows.Count; i > 0; i--)
{
int ID = Convert.ToInt32(dataGridView1.SelectedRows[i - 1].Cells[0].Value);
dataGridView1.Rows.RemoveAt(dataGridView1.SelectedRows[i - 1].Index);
//使用获得的ID删除数据库的数据
string SQL = "delete from UserInfo where UserId='"+ID.ToString()+"'";
int s =Convert.ToInt32(cl.Execute(SQL)); //cl是操作类的一个对像,Execute()是类中的一个方法
if (s!=0)
{
MessageBox.Show("成功删除选中行数据!");
}
}
break;
case DialogResult.No:
break;
}

 在上面代码中,需要按照dataGridview中的列下标进行筛选,如果是删除就进行删除,否则就不进行删除。操作时发现下标编号默认是文本框是编号【1,2,3】,行中有button,button编号【1,2,3】,这时按列来确定是否是选择的内容时就会出错。后来发现是dataGridview初始化时少了一个属性:

 this.dgv_AllUsers.AutoGenerateColumns = false;

添加上这行代码后可以按照统一下标操作。郁闷了半天才找到原因。

  #region 删除选中的行
            string buttonText = this.dgv_AllUsers.Rows[e.RowIndex].Cells[e.ColumnIndex].Value.ToString();
            //int CIndex = e.ColumnIndex;
            //按钮所在列为第五列,列下标从0开始的  
            if (buttonText == "删除")
            {
                //获取在同一行第一列的单元格中的字段值  
                string _UID =this.dgv_AllUsers[0, e.RowIndex].Value.ToString();
                string _Uname = this.dgv_AllUsers[1, e.RowIndex].Value.ToString();
                //MessageBox.Show(_UID.ToString());
                DialogResult RSS = MessageBox.Show(this, "确定要删除选中行( ID为" + _UID + ":,名称为:" + _Uname + " )的数据码?", "提示", MessageBoxButtons.YesNo, MessageBoxIcon.Warning);
                switch (RSS)
                {
                    case DialogResult.Yes:
                        jinlongDLL.DBHelper db = new DBHelper();
                        string SQL = "delete from users where id='" + _UID + "';";
                        int s = db.ExecuteSql(SQL);
                        if (s != 0)
                        {
                            MessageBox.Show("成功删除选中行数据!");
                        }
                        dgv_AllUsers_Init();//载入用户数据
                        break;
                    case DialogResult.No:
                        break;
                }
            }
            #endregion

  

posted @ 2016-05-04 15:58  wuling129  阅读(2743)  评论(0编辑  收藏  举报