在SQL Server 事务中使用Savepoints来保存提交点
2017-06-07 10:59
281 查看
在SQL Server中使用rollback会回滚所有的未提交事务状态,但是有些时候我们只需要回滚部分语句,把不需要回滚的语句提到事务外面来,虽然是个方法,但是却破坏了事务的ACID。
其实我们可以使用SQL Server中的Savepoints来解决上述问题。
示例如下:
1.先建立测试表:
CREATE TABLE [dbo].[ttt](
[Id] [int] NULL,
[mark] [int] NULL
)
2.SQL 语句
begin tran
insert into ttt values(3,'3');
save tran point1
insert into ttt values(4,'4');
rollback tran point1
commit
执行结果如下:
Id mark
3 3
可见,虽然3,4都在一个事务中,但是由于使用了SavePoints,所以3被提交了,4被回滚了。
其实我们可以使用SQL Server中的Savepoints来解决上述问题。
示例如下:
1.先建立测试表:
CREATE TABLE [dbo].[ttt](
[Id] [int] NULL,
[mark] [int] NULL
)
2.SQL 语句
begin tran
insert into ttt values(3,'3');
save tran point1
insert into ttt values(4,'4');
rollback tran point1
commit
执行结果如下:
Id mark
3 3
可见,虽然3,4都在一个事务中,但是由于使用了SavePoints,所以3被提交了,4被回滚了。
相关文章推荐
- 在SQL Server 事务中使用Savepoints来保存提交点
- 在SQL Server 事务中使用Savepoints来保存提交点 (转)
- 在SQL Server 事务中使用Savepoints来保存提交点
- 在SQL Server 事务中使用Savepoints来保存提交点
- 在SQL Server 事务中使用Savepoints来保存提交点
- 在 .NET 中使用 oracle 数据库 事务提交,事务保存点
- 在SQL Server存储过程中使用事务及返回值
- 个人学习代码保存:例4.在.net程序中使用事务处理
- 个人学习代码保存:例8.在存储过程中使用简单的事务处理
- 在asp.net Sql server (可以是存储过程)中使用事务回滚
- .NET下使用DataAdapter保存数据时,如何生成command语句及使用事务
- SQL server事务中的保存点(save)
- Hibernate3不使用事务无法保存或修改数据问题
- ASP.NET WEB群集使用SQL Server保存状态
- SQL SERVER存储过程中使用事务
- ASP.NET和SQL SERVER中使用事务示例
- .NET动态生成DataSet下使用DataAdapter保存数据时,如何生成command语句及使用事务(转)
- .NET下使用DataAdapter保存数据时,如何生成command语句及使用事务
- 使用SQL Server 2008的事务日志传送功能备份数据库
- Hibernate中自动使用线程局部变量保存Session和事务对象