holmes31415 2019-04-04 09:06 采纳率: 0%
浏览 1622
已采纳

C#插入mysql显示插入成功,但无法查询到数据

本人向mysql中插入一条数据,代码如下
MySqlCommand sqlCmd2 = new MySqlCommand();
sqlCmd2.CommandText = str1;
sqlCmd2.Connection = sqlCnn;
MySqlTransaction trans = sqlCnn.BeginTransaction();
sqlCmd2.Transaction = trans;
try
{
int k = sqlCmd2.ExecuteNonQuery();
}
catch (Exception e)
{
trans.Rollback();
}
程序执行过程中未抛出异常,并且执行ExecuteNonQuery有返回值,为1
但是在数据库中却看不到插入的数据。
然后我将
MySqlTransaction trans = sqlCnn.BeginTransaction();
sqlCmd2.Transaction = trans;
trans.Rollback();

这些代码去掉,则插入成功,数据库中,能看到新插入的数据,如下所示
主健 参数1
id num1
1 a
2 b
5 c

主健id我的设置是自增长,增量为1,由2变为5是因为我按上述第一种方法插入后显示插入成功,却查询不到数据所致。
请问发生这种情况的原因是什么,该如何解决?

  • 写回答

2条回答 默认 最新

  • threenewbee 2019-04-04 10:11
    关注

    catch (Exception e)
    {
    trans.Rollback();
    }
    finally
    {
    trans.Commit();
    }

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥20 vscode虚拟环境依赖包未安装
  • ¥15 odoo17关于owl开发js代码问题
  • ¥15 光纤中多普勒频移公式的推导
  • ¥15 怎么制作一个人脸识别门禁系统
  • ¥20 大华dss监控平台网络关闭登不进去
  • ¥15 请使用蚁群算法解决下列问题,并给出我完整的代码
  • ¥20 关于php录入完成后,批量更新数据库
  • ¥15 请教往复密封润滑问题
  • ¥15 cocos creator发布ios包
  • ¥15 comsol压电材料数据