第8章-游标事务锁课件.ppt
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《第8章-游标事务锁课件.ppt》由用户(晟晟文业)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 游标 事务 课件
- 资源描述:
-
1、学习要点:学习要点:游标的定义和使用方法 事务的定义、操作以及具体应用 锁的定义和使用方法8.1 游标游标8.2 事务事务8.3 锁锁 游标是一种数据结构。通过这种结构,程序可以将查询结果保存在其中,并可对其中某行(或某些行)的数据进行操作。游标中的数据保存在内存中,从其中提取数据的速度要比从数据表中直接提取数据的速度要快得多。8.1.1 游标的定义及优点游标的定义及优点 1游标的定义游标的定义 SELECT 语句返回的所有行的集合均作为一个整体处理,而无法对其中的一行或部分行做单独处理。而在实际开发中,尤其是在交互应用程序设计中,人们常常需要对SELECT语句所返回结果集合中的不同行做不同处
2、理。游标正是这样一种方法,它能够部分读取返回结果集合中的数据行,并允许应用程序通过游标定位修改表中数据。2游标的优点游标的优点 游标的主要好处是可以逐行的处理数据。通过游标允许程序对由select产生的结果集的每一行执行相同或不同的操作;允许从结果集中检索指定的行;允许结果集中的当前行被修改;允许被其它用户修改的数据在结果集中是可见的。8.1.2 游标的用法游标的用法 1声明游标声明游标 语法形式如下:DECLARE cursor_name CURSOR FOR select_statement FOR READ ONLY|UPDATE OF column_name ,.n v cursor_
3、name:是所定义的游标名称。cursor_name 必须遵从标识符规则。v select_statement:是定义游标结果集的标准 SELECT 语句。在游标声明的 select_statement内不允许使用关键字 COMPUTE、COMPUTE BY、FOR BROWSE 和INTO。v FOR READ ONLY:指出游标的结果集是只读的,不能修改。v FOR UPDATEOF column_name,.n:指出游标的结果集是可以被修改的。如果指定 OF column_name,.n 参数,则只允许修改所列出的列。如果在 UPDATE 中未指定列的列表,则可以更新所有列。例8-1 在
4、cjgl数据库中定义一个游标,其数据为表cj中的全部数据。Use cjglGODECLARE myCursor CURSORFor select*from cj2 2打开游标打开游标 OPEN cursor_name OPEN cursor_name v cursor_name 是已声明过的并且没有打开的游标名称。v 打开游标后,可以从全局变量CURSOR_ROWS中读取游标结果集合中的行数。例8-2 打开myCursor游标,替换上次提取行之后的行记录中的成绩=3,并显示结果。Use cjglGOOPEN myCursorPrint CURSOR_ROWSPrint CURSOR_ROWSF
5、ETCH NEXT FROM myCursorUpdate cj Set 成绩成绩=3Where CURRENT OF myCursorPrint CURSOR_ROWSPrint CURSOR_ROWSGO3从打开的游标中提取数据从打开的游标中提取数据 FETCH NEXT|PRIOR|FIRST|LAST|ABSOLUTE n|RELATIVE n FROM cursor_name INTO variable_name ,.n v NEXT:提取上次提取行之后的行,即向下移动。如果 FETCH NEXT 为对游标的第一次提取操作,则返回结果集中的第一行。NEXT 为默认的游标提取选项。v
6、PRIOR:提取上次提取行之前的行。如果 FETCH PRIOR 为对游标的第一次提取操作,则没有行返回并且游标置于第一行之前。v LAST:提取游标中的最后一行并将其作为当前行。ABSOLUTE n:如果 n 为正数,则提取游标中从第 1 行开始的第 n 行。如果 n 为负整数,则提取游标中的倒数第 n 行。v RELATIVE n:如果 n 为正数,则提取所上次提取行之后的第 n 行。如果 n 为负数,则提取上次所提取行之前的第 n 行。如果 n 为 0,则同一行被再次提取。v cursor_name:要从中进行提取的游标的名称。v INTO variable_name,.n:允许将提取操
7、作的列数据放到局部变量中。注意:FETCH语句每次只能提取一行数据。因为Transact-SQL游标不支持块(多行)提取操作。F E T C H 语 句 的 执 行 状 态 保 存 在 全 局 变 量FETCH_STATUS中,该变量有三种取值:当取值为0时,说明FETCH语句执行成功。当取值为-1时,说明FETCH 语句失败或此行不在结果集中。当取值为-2时,说明被提取的行不存在。4 4关闭游标关闭游标 当提取完游标结果集中的数据时,应及时调用CLOSE语句关闭游标,以便释放游标所占用的系统资源。CLOSE cursor_name v cursor_name 是要被关闭的游标名。例8-3 关
8、闭myCursor游标。CLOSE myCursor5 5释放(删除)游标释放(删除)游标由于关闭游标时并没有删除游标,因此,游标仍然占用着系统资源。则将其关闭后,还需要使用DEALLOCATE语句来释放游标所占用的系统资源。DEALLOCATE cursor_nameDEALLOCATE cursor_name例8-4 释放释放myCursor游标。DEALLOCATEDEALLOCATE myCursor8.1.3 使用游标修改数据使用游标修改数据 UPDATE语句和DELETE语句也支持游标操作,它们可以通过游标修改或删除游标基表中的当前数据行。这样,就可以通过游标更新和删除数据表中的数
9、据。UPDATE table_nameUPDATE table_nameSET SET 子句子句WHERE CURRENT OF cursor_nameWHERE CURRENT OF cursor_namev table_name:为需要修改的数据表名。v cursor_name:为游标名。例8-5 打开myCursor游标,替换所有行记录中的成绩=3。Use cjglGOOPEN myCursorFETCH NEXT FROM myCursorUpdate cj Set 成绩成绩=3DELETE FROM table_nameWHERE CURRENT OF cursor_namev ta
10、ble_name:为需要修改的数据表名。v cursor_name:为游标名。例8-6 打开myCursor游标,将游标“myCursor”中当前行中内容删除。Use cjglGOOPEN myCursorDELETE FROM cjWhere CURRENT OF myCursor8.2.1 8.2.1 什么是事务什么是事务 事务(Transaction)是SQL Server 中的单个逻辑工作单元,一个事务内的所有语句被作为一个整体执行。在事务执行过程中,如果遇到错误,则可以回滚事务,取消该事务所做的全部改变,从而保证数据库的一致性和可恢复性。也就是说,一个事务要么其中的语句全部正确执行,
11、要么全部语句不起作用。事务作为一个逻辑工作单元必须有四个属性,称为 ACID(原子性、一致性、隔离性和持久性)属性。v 原子性原子性:事务必须是原子工作单元;对于其数据修改,要么全都执行,要么全都不执行。v 一致性一致性:事务在完成时,必须使所有的数据都保持一致状态。v 隔离性隔离性:由并发事务所作的修改必须与任何其它并发事务所作的修改隔离。v 持久性持久性:事务完成之后,它对于系统的影响是永久性的。该修改即使出现系统故障也将一直保持。在SQL Server 中,系统将事务模式分为显式事务、隐式显式事务、隐式事务和自动事务事务和自动事务三种。1 1显示事务显示事务 显示事务是指由用户通过Tra
12、nsace-SQL 事务语句而定义的事务。这类事务又称为用户定义事务。(1)BEGIN TRANSACTION 标记一个显式本地事务的起始点。(2)COMMIT TRANSACTION 标志一个成功的显示事务或隐性事务的结束。(3)ROLLBACK TRANSACTION 将显式事务或隐式事务回滚到事务的起点或事务内 的某个保存点。(4)SAVE TRANSACTION 将显式事务回滚到事务的起点。2 2隐式事务隐式事务隐式事务是指在当前事务提交或回滚后,SQL Server 自动开始的事务。隐式事务不需要使用BEGIN TRANSACTION语句标识事务的开始,而只需要用户使用ROLLBAC
展开阅读全文