- 1
- 0
- 约5.05千字
- 约 17页
- 2017-06-02 发布于河南
- 举报
第7讲 事务
事 务 目标 理解事务的概念 掌握如何创建事务 为什么需要事务(1-1) 例如,银行转帐问题: 假定资金从帐户A转到帐户B,至少需要两步: 帐户A的资金减少 然后帐户B的资金相应增加 为什么需要事务(1-2) 假定张三的帐户直接转帐1000元到李四的帐户 为什么需要事务(1-3) 目前两个帐户的余额总和为:1000+1=1001元 为什么需要事务(1-4) 模拟实现转帐 : 从张三的帐户转帐1000元到李四的帐户 为什么需要事务(1-5) 错误原因分析: 什么是事务 事务(TRANSACTION)是作为单个逻辑工作单元执行的一系列操作 这些操作作为一个整体一起向系统提交,要么都执行、要么都不执行 事务是一个不可分割的工作逻辑单元 事务的特性 事务必须具备以下四个属性,简称ACID 属性: 原子性(Atomicity):事务是一个完整的操作。事务的各步操作是不可分的(原子的);要么都执行,要么都不执行 一致性(Consistency):当事务完成时,数据必须处于一致状态 隔离性(Isolation):对数据进行修改的所有并发事务是彼此隔离的,这表明事务必须是独立的,它不应以任何方式依赖于或影响其他事务 永久性(Durability):事务完成后,它对数据库的修改被永久保持,事务日志能够保持事务的永久性 如何创建事务 T-SQL使用下列语句来管理事务: 开始事务:BEGIN TRANSACTION 提交事务:COMMIT TRANSACTION 回滚(撤销)事务:ROLLBACK TRANSACTION 一旦事务提交或回滚,则事务结束。 判断某条语句执行是否出错: 使用全局变量@@ERROR; @@ERROR只能判断当前一条T-SQL语句执行是否有错,为了判断事务中所有T-SQL语句是否有错,我们需要对错误进行累计; 如: SET @errorSum=@errorSum+@@error 如何创建事务 了解事务的分类: 显示事务:用BEGIN TRANSACTION明确指定事务的开始,这是最常用的事务类型 隐性事务:通过设置SET IMPLICIT_TRANSACTIONS ON 语句,将隐性事务模式设置为打开,下一个语句自动启动一个新事务。当该事务完成时,再下一个 T-SQL 语句又将启动一个新事务 自动提交事务:这是 SQL Server 的默认模式,它将每条单独的 T-SQL 语句视为一个事务,如果成功执行,则自动提交;如果错误,则自动回滚 如何创建事务 使用事务解决银行转帐问题 如何创建事务 如何创建事务 演示:转帐1000,转帐失败的情况 如何创建事务 演示:转帐800,转帐成功的情况 总结 数据库事务具有如下特性: 原子性 一致性 隔离性 持久性 以上四个特性也称为ACID特性。 事务可以分为如下类型: 显式事务 隐性事务 自动提交事务 总结 Transact-SQL使用下列语句来管理事务: BEGIN TRANSACTION COMMIT TRANSACTION ROLLBACK TRANSACTION 银行转帐 帐户A 帐户B CREATE TABLE bank ( customerName CHAR(10), --顾客姓名 currentMoney MONEY --当前余额 ) GO ALTER TABLE bank ADD CONSTRAINT CK_currentMoney CHECK(currentMoney=1) GO INSERT INTO bank(customerName,currentMoney) VALUES(张三,1000) INSERT INTO bank(customerName,currentMoney) VALUES(李四,1) 创建帐户表,存放用户的帐户信息 添加约束:根据银行规定,帐户余额不能少于1元,否则视为销户 张三开户,开户金额为1000元 ;李四开户,开户金额1元 /*--转帐测试:张三转账1000元给李四--*/ --我们可能会这样这样编写语句 --张三的帐户少1000元,李四的帐户多1000元 UPDATE bank SET currentMoney=currentMoney-1000 WHERE customerName=张三 UPDATE bank SET currentMoney=currentMoney+1000 WHERE customerName=李四 GO --再次查看转帐后的结果。 SELECT * FROM bank GO 请问:执行转帐语句后,张三、李四的
您可能关注的文档
- 盛泽 婚庆方案.ppt
- 直接驱动电子小型花样缝纫机.doc
- 直线方程练习(难).doc
- 相互作用单元练习题一(新课标人教版有答案).doc
- 相互作用单元练习题二(新课标人教版有答案).doc
- 相关、回归与因果关系 [兼容模式].pdf
- 相机的变焦原理.pdf
- 省5——万绿湖风景区.doc
- 相约2013.ppt
- 省干部培训-创造在您身边.doc
- 浙江省温州市2024-2025学年七年级上学期语文期末考查卷.docx
- 精品解析:北京市建华实验学校2024-2025学年七年级下学期期中英语试题(原卷版).docx
- 精品解析:北京市通州区2024-2025学年七年级下学期期末考试英语试卷(原卷版).docx
- 精品解析:北京市回民学校2024-2025学年九年级上学期期中语文试题(解析版).docx
- 精品解析:北京市海淀区2025-2026学年九年级上学期期末语文试题(解析版).docx
- 精品解析:北京市东城区汇文中学2025-2026学年八年级上学期期中语文试题(原卷版).docx
- 精品解析:北京市回民学校2024-2025学年九年级上学期期中语文试题(原卷版).docx
- 精品解析:2024-2025学年广东省广州市从化区街口镇中心小学人教版五年级上册期中测试数学试卷(解析版).docx
- 精品解析:北京市通州区2024-2025学年七年级下学期期末考试英语试卷(解析版).docx
- 精品解析:北京市建华实验学校2024-2025学年七年级下学期期中英语试题(解析版).docx
最近下载
- 完整版04融创物业秩序服务可视化标准.ppt
- 统编人教部编版小学语文一年级下册语文标点符号练习+答案 .pdf VIP
- EPS系统参数及整车性能的匹配.pdf VIP
- 湖北省武汉市江岸区2023-2024学年六年级上学期语文期末试卷(含答案)2.docx VIP
- 2025年中国水性粘结剂行业市场全景调研及前景战略研判报告.docx
- EPS系统对车辆操纵稳定性影响的仿真的分析研究.pdf VIP
- 幼儿园年度工作总结卫生保健.pptx
- 职业健康管理:电力行业职业健康课件.pptx VIP
- 2026.01.01施行《招标人主体责任履行指引》PPT课件.pptx VIP
- 湖北省武汉市2022-2023学年六年级上学期语文期末试卷(含答案).pdf VIP
原创力文档

文档评论(0)