c#连接关闭了,事务并没有关闭

时间:2023-03-08 17:00:39
c#连接关闭了,事务并没有关闭

用的是mysql引擎是InnoDB,用到了连接池。

c#连接关闭了,事务并没有关闭

连接还没关闭,但是事务开启,并执行了更新id=14的操作,这是把这一行锁住了,可以查询,但不能更新和删除,必需等锁释放,提交换回滚事务时锁被释放。直接关闭连接锁也会被释放,但是该连接上的事务还存在,所以下面重新打开连接,然后提交事务,但是此时提交事务只是释放该连接的事务,并不会执行上面的更新操作。(ps:第二次打开连接,但是连接的con.ServerThread并不是一样的,上面的是44,下面的是45.但是提交事务没出错,所以应该是同一个。下面做验证。)

c#连接关闭了,事务并没有关闭

第二次重新实例化一个连接,提交事务时异常了且con.ServerThread也是不一样的,所以证明上面的第二次打开连接是同一个。

如果要重新开启事务,需要重新得到一个事务。不然是不起作用的,可以试着把红线旁边的代码注释,然后单步调试,看数据库的数据变化。

c#连接关闭了,事务并没有关闭

C#代码。

 string connString = "Server=localhost;Database=test;Uid=root;Pwd=root;Charset=utf8;pooling=true;Min Pool Size=2;Max Pool Size=20;";
MySqlConnection con = new MySqlConnection(connString);
con.Open();
string sql = "update Nc_A set name='gfeng1' where id=14";
MySqlCommand com = new MySqlCommand(sql, con);
MySqlTransaction tran = con.BeginTransaction(); int rowcount = com.ExecuteNonQuery();
//con.Close();
//con.Dispose();
//tran.Commit();
//tran.Rollback();
con.Close();
//con.Dispose();
//con = new MySqlConnection(connString);
con.Open();
tran = con.BeginTransaction();
//tran = con.BeginTransaction();
rowcount = com.ExecuteNonQuery();
tran.Commit();
//tran.Commit();
con.Close();

C# Code

sql代码

 select *
from nc_a
where Id=14 DELETE FROM nc_a WHERE Id=15 UPDATE nc_a SET `name`='gfeng20' WHERE Id=14 UPDATE nc_a
SET `name`=CONCAT(`name`,'')
WHERE id=14

sql Code

表结构

 CREATE TABLE `nc_a` (
`Id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(250) DEFAULT NULL,
`phone` varchar(11) DEFAULT NULL,
`address` varchar(50) DEFAULT NULL,
PRIMARY KEY (`Id`)
) ENGINE=InnoDB AUTO_INCREMENT=679069 DEFAULT CHARSET=latin1;

表结构

连接mysql需要MySql.Data.dll;mysql查看连接数的命令是show processlist;