DataGridView列中加CheckBox绑定数据库

程序功能:

1.在DataGridView中添加CheckBox列,然后使用DataGridView来绑定Oracle数据

2.绑定的数据在DataGridView显示时选择需要显示的数据,然后勾选CheckBox来删除数据库中的数据

private System.Windows.Forms.DataGridView dgvImageInfo; 

 private DataGridViewCheckBoxColumn dgvCol = new DataGridViewCheckBoxColumn();//DataGridView列中加CheckBox

this.dgvImageInfo.AllowUserToAddRows = false;//设置DataGridView使DataGridView不允许增加行
 this.dgvImageInfo.AllowUserToDeleteRows = false;//设置DataGridView使DataGridView不允许删除数据
  this.dgvImageInfo.AllowUserToResizeRows = false; //设置DataGridView使DataGridView不允许就该数据


/// <summary>

        /// 更改数据源绑定内容
        /// </summary>
        private void RebindDbSource()
        {

          //修改DataGridView列中CheckBox 的属性

   dgvImageInfo.Columns.Clear();

            dgvCol.HeaderText = "是否删除";
            dgvCol.DataPropertyName = "IsChecked";
            dgvCol.ReadOnly = false;
            dgvImageInfo.Columns.Add(dgvCol);


            DispalyDtName(dgvImageInfo,"ID","主键");
            DispalyDtName(dgvImageInfo, "DisplayName", "名称");
            DispalyDtName(dgvImageInfo,"InputDateTime","上传时间");
            dgvImageInfo.Columns["ID"].Visible = false;


        }

//显示数据库中部分数据

        private void DispalyDtName(DataGridView dgv, string dataPropertyName, string headerText)
        {
            dgv.AutoGenerateColumns = false;
            DataGridViewTextBoxColumn obj = new DataGridViewTextBoxColumn();
            obj.DataPropertyName = dataPropertyName;
            obj.HeaderText = headerText;
            obj.Resizable = DataGridViewTriState.True;
            dgv.Columns.AddRange(new DataGridViewColumn[] {obj});


        }

 /// <summary>
        /// 删除数据库中数据
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void BtnDelete_Click(object sender, EventArgs e)
        {
            if (dgvImageInfo.SelectedRows.Count == 0)
            {
                MessageBox.Show("请先选中一行在进行删除","删除区域",MessageBoxButtons.OK,MessageBoxIcon.Exclamation);
                return;
            }
            if(MessageBox.Show("你确定要删除该记录?","信息",MessageBoxButtons.YesNo) == DialogResult.Yes)
            {
                for (int i = 0; i < dgvImageInfo.Rows.Count;i++ )
                {
                    
                    string re_value = dgvImageInfo.Rows[i].Cells[0].EditedFormattedValue.ToString();
                    if (re_value == "True")
                    {
                        _MrifID = int.Parse(dgvImageInfo.Rows[i].Cells["ID"].Value.ToString());
                        b_mrifmeta_t.Delete(_MrifID);
                    }
                }
                DataTable dt = b_mrifmeta_t.GetAllList().Tables[0];
                dgvImageInfo.DataSource = dt.DefaultView;
                RebindDbSource();
            }
        }

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在C#中,可以通过`DataGridView.DataSource`属性将DataGridView控件与数据源,实现数据库中的数据。 以下是示例代码: ```csharp // 假设已经创建了DataGridView控件实例 dgv,并连接了名为 MyDatabase 的数据库 // 从数据库中查询数据 string sql = "SELECT * FROM MyTable"; SqlDataAdapter adapter = new SqlDataAdapter(sql, "Data Source=.;Initial Catalog=MyDatabase;Integrated Security=True"); DataTable table = new DataTable(); adapter.Fill(table); // 将DataTable对象与DataGridView控件 dgv.DataSource = table; ``` 在上述代码中,首先通过`SqlDataAdapter`类从数据库中查询数据,并将查询结果填充到一个`DataTable`对象中。然后,将该`DataTable`对象与`DataGridView`控件实例的`DataSource`属性,这样就可以将控件的数据库中的数据进行。 需要注意的是,为了确保能够正确地显示数据库中的数据,需要为`DataGridView`控件中的每一设置`DataPropertyName`属性,该属性对应数据库中的名。例如: ```csharp // 设置DataGridView控件中的数据库中的 dgv.Columns["column1"].DataPropertyName = "Column1NameInDatabase"; dgv.Columns["column2"].DataPropertyName = "Column2NameInDatabase"; // ... ``` 其中,`"column1"`和`"column2"`是DataGridView控件中的名,`"Column1NameInDatabase"`和`"Column2NameInDatabase"`是数据库中的名,需要根据实际情况进行设置。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值