位置: 编程技术 - 正文

MSSQL 事务说明(sql事务处理)

编辑:rootadmin
1.什么是事务:事务是一个不可分割的工作逻辑单元,在数据库系统上执行并发操作时事务是做为最小的控制单元来使用的。他包含的所有数据库操作命令作为一个整体一起向系提交或撤消,这一组数据库操作命令要么都执行,要么都不执行。 2.事务的语句 开始事物:BEGIN TRANSACTION 提交事物:COMMIT TRANSACTION 回滚事务:ROLLBACK TRANSACTION 3.事务的4个属性 ①原子性(Atomicity):事务中的所有元素作为一个整体提交或回滚,事务的个元素是不可分的,事务是一个完整操作。 ②一致性(Consistemcy):事物完成时,数据必须是一致的,也就是说,和事物开始之前,数据存储中的数据处于一致状态。保证数据的无损。 ③隔离性(Isolation):对数据进行修改的多个事务是彼此隔离的。这表明事务必须是独立的,不应该以任何方式以来于或影响其他事务。 ④持久性(Durability):事务完成之后,它对于系统的影响是永久的,该修改即使出现系统故障也将一直保留,真实的修改了数据库 4.事务的保存点 SAVE TRANSACTION 保存点名称 --自定义保存点的名称和位置 ROLLBACK TRANSACTION 保存点名称 --回滚到自定义的保存点 -------------------实------------------例---------------------------- BEGIN TRANSACTION--开始事务 DECLARE @errorSun INT --定义错误计数器 SET @errorSun=0 --没错为0 UPDATE a SET id= WHERE a=1 --事务操作SQL语句 SET @errorSun=@errorSun+@@ERROR --累计是否有错 UPDATE aa SET id=2 WHERE a=1 --事务操作SQL语句 SET @errorSun=@errorSun+@@ERROR --累计是否有错 IF @errorSun<>0 BEGIN PRINT '有错误,回滚' ROLLBACK TRANSACTION--事务回滚语句 END ELSE BEGIN PRINT '成功,提交' COMMIT TRANSACTION--事务提交语句 END 示例:创建一个存储过程,向两个表中同时插入数据 事务的分类 按事务的启动与执行方式,可以将事务分为3类: 显示事务 也称之为用户定义或用户指定的事务,即可以显式地定义启动和结束的事务。分布式事务属于显示事务 自动提交事务 默认事务管理模式。如果一个语句成功地完成,则提交该语句;如果遇到错误,则回滚该语句。 隐性事务 当连接以此模式进行操作时,sql将在提交或回滚当前事务后自动启动新事务。无须描述事务的开始,只需提交或回滚每个事务。它生成连续的事务链。 一、显示事务 通过begin transacton、commit transaction、commit work、rollback transaction或rollback work等语句完成。 1、启动事务 格式:begin tran 事务名或变量 with mark 描述 2、结束事务 格式:commit tran 事务名或变量 (事务名与begin tran中的事务名一致 或commit work 但此没有参数 3、回滚事务 rollback tran 事务名或变量 | savepoint_name | savepoint_variable 或rollback work 说明:清除自事务的起点或到某个保存点所做的所有数据修改 4、在事务内设置保存点 格式:save tran savepoint_name | savepoint_variable 示例: 可以知道,上面的语句执行后,在book中插入了一笔记录,而并没有删除。因为使用rollback tran mysave 语句将操作回滚到了删除前的保存点处。 5、标记事务 格式:with mark 例:使用数据库标记将日志恢复到预定义时间点的语句 在事务日志中置入一个标记。请注意,被标记的事务至少须提交一个更新,以标记该日志。 BEGIN TRAN MyMark WITH MARK UPDATE pubs.dbo.LastLogMark SET MarkTime = GETDATE() COMMIT TRAN MyMark 按照您常用的方法备份事务日志。 BACKUP LOG pubs TO DISK='C:BackupsFullbackup.bak' WITH INIT 现在您可以将数据库恢复至日志标记点。首先恢复数据库,并使其为接受日志恢复做好准备。 RESTORE DATABASE pubs FROM DISK=N'C:BackupsFullbackup.bak' WITH NORECOVERY 现在将日志恢复至包含该标记的时间点,并使其可供使用。请注意,STOPAT在数据库正在执行大容量日志时禁止执行。 RESTORE LOG pubs FROM DISK=N'C:BackupsLogbackup.bak' WITH RECOVERY, STOPAT='// ::' 5、不能用于事务的操作 创建数据库 create database 修改数据库 alter database 删除数据库 drop database 恢复数据库 restore database 加载数据库 load database 备份日志文件 backup log 恢复日志文件 restore log 更新统计数据 update statitics 授权操作 grant 复制事务日志 dump tran 磁盘初始化 disk init 更新使用sp_configure后的系统配置 reconfigure 二、自动提交事务 sql连接在begin tran 语句启动显式事务,或隐性事务模式设置为打开之前,将以自动提交模式进行操作。当提交或回滚显式事务,或者关闭隐性事务模式时,将返回到自动提交模式。 示例: 由于编译错误,使得三个insert都没执行 没有任何结果返回 三、隐式事务 通过 API 函数或 Transact-SQL SET IMPLICIT_TRANSACTIONS ON 语句,将隐性事务模式设置为打开。下一个语句自动启动一个新事务。当该事务完成时,再下一个 Transact-SQL 语句又将启动一个新事务。 当有大量的DDL 和DML命令执行时会自动开始,并一直保持到用户明确提交为止,切换隐式事务可以用SET IMPLICIT_TRANSACTIONS 为连接设置隐性事务模式.当设置为 ON 时,SET IMPLICIT_TRANSACTIONS 将连接设置为隐性事务模式。当设置为 OFF 时,则使连接返回到自动提交事务模式 语句包括: alter table insert open create delete revoke drop select fetch truncate table grant update 示例: 下面使用显式与隐式事务。它使用@@tracount函数演示打开的事务与关闭的事务: 执行结果: 使用显示事务 事务内的事务数目:2 事务外的事务数目:1 使用隐式事务 事务内的事务数目:1 事务外的事务数目:0 四、分布式事务 跨越两个或多个数据库的单个sql server中的事务就是分布式事务。 与本地事务区别:必须由事务管理器管理,以尽量避免出现因网络故障而导致一个事务由某些资源管理器成功提交,但由另一些资源管理器回滚的情况。 sql server 可以由DTc microsoft distributed transaction coordinator 来支持处理分布式事务,可以使用 BEgin distributed transaction 命令启动一个分布式事务处理 分二阶段: A 准备阶段 B 提交阶段 执行教程: 1、sql 脚本或应用程序连接执行启动分布式事务的sql语句 2、执行该语句的sql在为事务中的主控服务器 3、脚本或应用程序对链接的服务器执行分布式查询,或对远程服务器执行远程存储过程。 4、当执行了分布式查询或远程过程调用后,主控服务器将自动调用msdtc以便登记分布式事务中链接的服务器和远程服务器 5、当脚本或应用程序发出commit或rollback语句时,主控sql将调用msdtc管理两阶段提交过程,或者通知链接的服务器和远程服务器回滚其事务。 mssql 事务的一个例子

推荐整理分享MSSQL 事务说明(sql事务处理),希望有所帮助,仅作参考,欢迎阅读内容。

MSSQL 事务说明(sql事务处理)

文章相关热门搜索词:sql server事务怎么写,mysql myisam事务,mysql 事务sql,sql事务处理,mysql 事务sql,sql事务处理,mysql 事务sql,mysql事务sql语句怎么实现,内容如对您有帮助,希望把文章链接给更多的朋友!

SQLServer中临时表与表变量的区别分析 在实际使用的时候,我们如何灵活的在存储过程中运用它们,虽然它们实现的功能基本上是一样的,可如何在一个存储过程中有时候去使用临时表而不

IN&EXISTS与NOT IN&NOT EXISTS 的优化原则小结 1.EXISTS的执行流程select*fromt1whereexists(selectnullfromt2wherey=x)可以理解为:forxin(select*fromt1)loopif(exists(selectnullfromt2wherey=x.x)thenOUTPUTTHERECORDendifendloop对于in和exists

SQL Server数据库开发的二十一条法则 在这里,我不打算介绍使用SQLServer的窍门,也不能提供一个包治百病的方案,我所做的是总结一些经验----关于如何形成一个好的设计。这些经验来自我

标签: sql事务处理

本文链接地址:https://www.jiuchutong.com/biancheng/349564.html 转载请保留说明!

上一篇:SQLServer触发器创建、删除、修改、查看示例代码(sql server触发器的编写与使用)

下一篇:SQLServer中临时表与表变量的区别分析(sql server临时表创建语句)

  • 所得税资产和所得税费用
  • 税率如何计算公式
  • 增值税纳税义务发生地点的规定
  • 管理会计期末存货计算公式
  • 所得税费用的余额期末时应转入利润分配账户
  • 进项税加计抵减生产性服务
  • 境外企业所得税税率
  • 退运出口货物的报关流程
  • 新办企业能否享受留抵退税
  • 购销商品分类核算方法有
  • 缴纳补充公积金的外企
  • 劳务公司差额征税怎么计算
  • 客户给现金
  • 怎么辨认专用发票真伪
  • 酒店产权式经营业主取得的收入按股利红利所得
  • 不动产进项税抵扣规定2016
  • 应收款计提
  • 库存周转天数计算实例
  • 自然人是否适用财政部税务总局2022年第15号公告
  • 允许扣除的土地价款怎么计算例题
  • linux 将一个文件的内容给另一个文件
  • 生产车间的各种费用
  • 花卉盆景苗木
  • 接受捐赠收入要计入销售收入吗
  • scm wms
  • 已收到发票未认证已付款怎么做分录
  • phpifelse
  • 收入汇缴账户可以冻结吗
  • 神舟战神k670c-g4e1游戏笔记本怎么样?
  • nfcmp3
  • 不列颠哥伦比亚大学排名
  • 个体户何去何从
  • 中文最早出现的时期
  • 调整以前年度损益调整分录费用调增
  • 新成立公司建账
  • 利息资本化怎么计算
  • openpose的输出
  • html入门基础
  • 企业一次性收取租金如何缴纳增值税
  • 视觉slam有多难
  • 可供出售金融资产的会计处理
  • 成本利润率算出的不含税吗
  • 样品属于存货吗
  • 周转材料二级科目有哪些
  • centos7.9 防火墙
  • 什么情况下需要满足m>>m
  • 当期可抵扣进项税额包括进项转出额吗
  • 小规模企业跨月发票如何冲红
  • 个体工商户可以抵扣进项吗
  • 不合格机器设备怎么处理
  • 经营范围变更银行变更需要什么资料
  • 工会经费计提比例0.8%
  • 产权转让印花税减半征收
  • 在建工程领用原材料
  • 业务招待费的列支范围
  • 扣除土地价款
  • 特殊销售方式下的销售额确认图文怎么做
  • 资产负债表月报的期初余额填什么
  • 推广费计入哪个科目
  • 收到的普通发票被对方作废
  • 在建工程领用工程物资
  • sql指定字段添加数据
  • 屏幕右下角显示A2
  • 安装完xp系统直接黑屏怎么办
  • win8.1技巧
  • win10系统更新后网速变慢
  • extJS中常用的4种Ajax异步提交方式
  • 使用jquery
  • css滚动条设置
  • 到了这个年纪吉他谱完整版
  • 每天自动重启命令
  • javascript怎么用
  • java对象怎么比较
  • java模拟支付功能
  • 重新加载activity
  • 怎么向税务局举报不开票行为
  • 怎么看有没有欠税
  • 企业年报通怎么注销
  • 烟台税务热线电话查询
  • 02112366电子税务局
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设