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的一个问题 。非常感谢。
接近 2 年之前 回复
caozhy
caozhy   Ds   Rxr 2016.09.07 23:01

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

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

具体的错误内容是什么?

kawun
kawun 没有错误内容。executenonquery的返回值都显示是正常的,但是在数据库里却显示并没有修改。 我看过了,查询和插入都是没有问题的,只有删除和修改两个操作出现这种情况。我以为是使用access数据库的问题,所以我把数据库改成mysql,结果还是一样
接近 2 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!
其他相关推荐
国际标准智商测试题 (转载)
​国际标准智商测试题 (转载)     智商,就是IQ(Intelligence Quotient的简称),通俗地可以理解为智力,是指数字、空间、逻辑、词汇、创造、记 忆等能力,它是德国心理学家施特恩在1912年提出的。智商表示人的聪明程度:智商 越高,则表示越聪明。想检验自己的智商是多少吗?这并不困难,以下就是一例国内 较权威的IQ测试题,请在30分钟内完成(30题),之后你就
众数的程序(使用到快速排序)
以下这个众数的程序,帮忙看下哪里出错了?
菜单程序,c
里面有许多错误,希望大神帮我改一下,十分感谢,拜托了。。有没有哪位大神愿意的
文件内容
帮我看看哪里错了,为什么不能连接数据库呢?一运行就出错
xshell5简体中文版安装包
xshell5简体中文版安装包,使用方便,一直下一步就可以安装完成。
构建JDK8报错了,哪位大神能帮忙看下什么原因 ?
构建JDK8报错了,哪位大神能帮忙看下什么原因 ?
大学生贷款
该系统分为三个基本的角色,分别是学生、校方负责人、银行负责人,对应的功能你们自己可以看看,我自己的毕设课题,希望对你有用。
TXT在线小说管理器
不知道哪里写错了,各位大神帮忙指点下,告诉怎么进行修改
C#学生管理系统
我在学校做的学生管理系统<br>但是没做完,哪位可以拿去帮我修改不?用C#做的
Android Binder驱动源码下载地址
最近在看《Android框架揭秘》,看到第七章 Android Binder IPC时,其中有涉及到Binder驱动的代码,想了解一下, 找了半天没有一个有效的链接参考,自己动手找: https://android.googlesource.com/kernel/common.git/+/android-3.4/drivers/staging/android/ 我个人测试发现,使