本人向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是因为我按上述第一种方法插入后显示插入成功,却查询不到数据所致。
请问发生这种情况的原因是什么,该如何解决?