因疏漏而产生的bug:“违反并发性: DeleteCommand 影响了预期 1 条记录中的 0 条。“

本人菜鸟,欢迎好心人,不欢迎喷子
本博客仅记录个人遇到的bug及解决办法,局限性较强。
在这里插入图片描述
原因一句话:虽然数据库中有id,但DataTable中id为空——表格还没读取到数据库自动生成的id,就要根据该id删掉该记录
(系统:where id = xx个锤子, 我怎么让数据库听话?这id还被数据库蒙在里面呢!)
解决办法(懒):在adapter.update(dt);之后重新从数据库读取数据,以获取自动生成的id值。

 private void button1_Click(object sender, EventArgs e)
 {
        adapter.Update(dt);
        Init();//重新读取数据,以获得id
 }

解决办法(真):实现adapter.RowUpdated事件,添加一条记录就立刻取出id

        void OnRowUpdated(object sender,MySqlRowUpdatedEventArgs e)
        {
            switch (e.Row.RowState)
            {
                case DataRowState.Added://如果该记录是新增记录
                    int? stu_id = Program.myDB.get_a_int("select max(id) from student;");
					//将id放到表格中,让系统能读取到id,从而能够删除数据库数据
                    e.Row["id"] = stu_id;
                    break;                
            }
        }
		void Init(string sql)
		{
            adapter = new MySqlDataAdapter(sql, conn);
            dt = new DataTable();
            adapter.Fill(dt);
            dataGridView1.DataSource = dt;            
            MySqlCommandBuilder cb = new MySqlCommandBuilder(adapter); 

			//绑定事件
            adapter.RowUpdated += OnRowUpdated;
        }

注意,我的bug是单机操作出现的

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值