sql 语句中commit的作用:
如果 @@TRANCOUNT 大于 1,则 COMMIT TRANSACTION使 @@TRANCOUNT 按 1 递减并且事务将保持活动状态。
如果 @@TRANCOUNT 为 1,COMMIT TRANSACTION 使得自从事务开始以来所执行的所有数据修改成为数据库的永久部分,释放事务所占用的资源,并将 @@TRANCOUNT 减少到 0。
扩展资料
使用COMMIT提交当前事务,使事务中执行的变更永久化,所有事务的更改都将为其他事务可见,而且保证当崩溃发生时的可持续性;
可以使用此语句终止SET TRANSACTION语句的只读事务;
可以使用此语句手动提交疑问在分布式的事务上;
通过修改的表,查看事务期间所作的任何更改,但其他用户不能看到所做的更改。
参考资料来源:百度百科-COMMIT
标志一个成功的隐性事务或显式事务的结束。如果 @@TRANCOUNT 为 1,COMMIT TRANSACTION 使得自从事务开始以来所执行的所有数据修改成为数据库的永久部分,释放事务所占用的资源,并将 @@TRANCOUNT 减少到 0。如果 @@TRANCOUNT 大于 1,则 COMMIT TRANSACTION 使 @@TRANCOUNT 按 1 递减并且事务将保持活动状态。
sql语句有什么时候要commit,有时候不用commit的原因:
DML需要提交(insert、update、delete)
DDL会自动提交(create、alter ...)
提交到数据库中
你修改的数据只有commit后才更新到table中
commit是提交的意思啊。
如果你设置了autocommit,就不用自己commit了。否则自己控制事务就要自己commit。