SqlServer批量刷数据执行事务回滚语句备份

      企业进行对数据库执行刷数据工作,一段很长的语句希望同时成功或者失败时用到。

1.建立测试环境

/************************************************************
 * Code formatted by SoftTree SQL Assistant ?v6.5.278
 * Time: 2016/9/29 21:33:55
 ************************************************************/
---建立测试环境
CREATE DATABASE TestTransaction
USE TestTransaction
GO
CREATE TABLE testTable
(
    testId       INT PRIMARY KEY IDENTITY,
    testName     VARCHAR(20) NOT NULL
);

2.执行事务

---开始

BEGIN TRY
    BEGIN TRANSACTION
        INSERT INTO testTable VALUES('3')     
         INSERT INTO testTable VALUES('5')
         INSERT INTO testTable VALUES( (SELECT testName FROM testTable WHERE testId=1))---将id为1的记录执行insert
         INSERT INTO testTable VALUES( (SELECT MAX(testName) FROM testTable WHERE testId=1))---聚合函数保证返回记录只有一条即可
    COMMIT TRANSACTION
END TRY
BEGIN CATCH
    ROLLBACK TRANSACTION
    PRINT '有语句插入失败,事务已回滚'
END CATCH

测试过提交和回滚事务正常。

3.辅助语句

---删除表,还原自增从1开始
TRUNCATE TABLE testTable

---显示插入自增列
SET IDENTITY_INSERT testTable ON
INSERT INTO testTable(testid,testName) VALUES(32,'5')
SET IDENTITY_INSERT testTable off

注意:

1.set identity_insert只对当前会话生效。

2.set identity_insert 表名 ON 设置后,必须显示指定Id(Insert into 里面要写入id的列),否则插入错误。如insert into table_name values('111')将报错。

   向自增ID插入指定值。 报错:“当 IDENTITY_INSERT 设置为 OFF 时,不能为表 ' ' 中的标识列插入显式值”。

   插入语句未显示指定ID。 报错:“仅当使用了列列表并且 IDENTITY_INSERT 为 ON 时,才能为表' '中的标识列指定显式值”。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Java架构师历程

sql必会基础1

ALTER TABLE old_table_name RENAME [TO] new_table_name

14420
来自专栏乐沙弥的世界

PL/SQL --> DBMS_DDL包的使用

为了便于建立性能良好的PL/SQL程序,Oracle提供了大量的系统包供使用。Oracle提供的这些包扩展并增强了数据库的一些功能,以及突

12640
来自专栏康怀帅的专栏

MySQL 初级命令

本文列举了一些初级的 MySQL 命令。 创建 数据库 CREATE DATABASE 数据库名; 数据表 CREATE TABLE IF NOT EXISTS...

29770
来自专栏王磊的博客

MS SQL查询库、表、列数据结构信息汇总

前言 一般情况我们下,我们是知道数据库的表、列信息的(因为数据库是我们手动设计),但特殊情况下,如果你只能拿到数据库连接信息,也就是知道的一个数据库名的情况下,...

45040
来自专栏乐沙弥的世界

PL/SQL --> DML 触发器

何谓触发器?简言之,是一段命名的PL/SQL代码块,只不过该代码块在特定的条件下被触发并且执行。对于这样的代码我们称之为触发器

11530
来自专栏闵开慧

phpmyadmin中导入文件时显示 No database selected

错误 SQL 查询: -- 数据库: `7789_pay` -- -- -------------------------------------...

42260
来自专栏乐沙弥的世界

使用导出导入(datapump)方式将普通表切换为分区表

      随着数据库数据量的不断增长,有些表需要由普通的堆表转换为分区表的模式。有几种不同的方法来对此进行操作,诸如导出表数据,然后创建分区表再导入数据到分区...

7810
来自专栏性能与架构

MySQL 8.0 新特性 :隐藏索引 Invisible Indexes

隐藏索引有什么作用 MySQL 8.0 支持了 Invisible Indexes 隐藏索引 这个特性,可以把某个索引设置为对优化器不可见,生成查询计划时便不使...

55190
来自专栏乐沙弥的世界

收集统计信息导致索引被监控

      对于索引的调整,我们可以通过Oracle提供的索引监控特性来跟踪索引是否被使用。尽管该特性并未提供索引使用的频度,但仍不失为我们参考的方式之一。然而...

8320
来自专栏Netkiller

数据库记录安全解决方案

数据库记录安全解决方案 http://netkiller.github.io/journal/mysql.security.html 摘要 数据库记录防删除,放...

42760

扫码关注云+社区

领取腾讯云代金券