2 kawun kawun 于 2016.09.07 22:55 提问

C#哪位大神帮我看下,我哪里错了

代码如下:

//点击删除
    private void delete_btn_Click(object sender, EventArgs e)
    {
        if (productId == -1)
        {
            MessageBox.Show("请先选择产品");
            return;
        }
        MessageBox.Show(productId.toString());
        DBHelper.conn.Open();
        OleDbTransaction tran = DBHelper.conn.BeginTransaction();
        string deleteProduct = string.Format(@"update product set p_delete_flag = 1 where p_id = {0}", productId);
        OleDbCommand deleteProductCmd = new OleDbCommand(deleteProduct, DBHelper.conn);
        deleteProductCmd.Transaction = tran;
        string deleteRate = string.Format(@"update rate set r_delete_flag = 1 where r_p_id = {0}", productId);
        OleDbCommand deleteRateCmd = new OleDbCommand(deleteRate, DBHelper.conn);
        deleteRateCmd.Transaction = tran;
        try
        {
            int a = deleteProductCmd.ExecuteNonQuery();
            MessageBox.Show(a.ToString());
            int b = deleteRateCmd.ExecuteNonQuery();
            MessageBox.Show(b.ToString());
            MessageBox.Show("删除成功");
        }
        catch (Exception ex)
        {
            MessageBox.Show(ex.Message);
            tran.Rollback();
        }
        finally
        {
            deleteProductCmd.Dispose();
            deleteRateCmd.Dispose();
            DBHelper.conn.Close();
        }
    }

productId = 21

a= 1 数据库确实是一行
b=2 数据库里确实存在两行
返回数据库一看。。。一点没变

3个回答

yongyong521
yongyong521   2016.09.09 09:57
已采纳

缺少事务的提交操作吧,只看到了事务开始BeginTransaction()和滚回Rollback(),怎么没有提交啊

kawun
kawun 妈的!!!! 果然!!!谢谢 谢谢 谢谢。我一直在想其他问题,没想是这么sb的一个问题 。非常感谢。
大约一年之前 回复
caozhy
caozhy   Ds   Rxr 2016.09.07 23:01

这个要结合你的数据库的表定义、数据库连接、数据库中的数据以及你的查询条件输入去看,建议你通过调试程序去解决。

kawun
kawun 另外 我把sql语句贴到数据库里p_id=21 也能改变值 显示正常。但是在程序里确不起作用
大约一年之前 回复
kawun
kawun executenonquery的返回值都是正确的,delete_flag 都为0
大约一年之前 回复
kaoziji
kaoziji   2016.09.08 22:36

具体的错误内容是什么?

kawun
kawun 没有错误内容。executenonquery的返回值都显示是正常的,但是在数据库里却显示并没有修改。 我看过了,查询和插入都是没有问题的,只有删除和修改两个操作出现这种情况。我以为是使用access数据库的问题,所以我把数据库改成mysql,结果还是一样
大约一年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片