- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
(SQL应用实例PPT
教学目标 本章主要学习SQL Server 2005中的游标、事务和锁的相关知识,包括游标概述、游标实例、事务处理、并发控制、锁的类型、锁的使用和死锁。 本章导航 1、游标(Cursor)的定义: 关系数据库中的操作会对整个行集产生影响,由SELECT语句返回的行集包括所有满足该语句中WHERE子句中条件的行,所返回的所有行被称为结果集。游标允许用户访问处理结果集中的一行或部分行,而不是对整个行集进行操作。 SQL Server 2005通过游标提供了对一个结果集进行逐行处理的能力。游标也可以被看作是一个表中的记录指针,该指针与某个查询结果集相联系。 2、游标的优点如下: 允许定位在结果集的特定行。 从结果集的当前位置检索一行或多行。 支持对结果集中当前位置的行进行数据修改。 注意:游标实际上作为面向集合的数据库管理系统和面向行的程序设计的桥梁,使得这两种处理方式通过游标沟通起来。 3、在SQL Server 2005中使用游标的一般步骤如下: (1)声明游标(DECLARE CURSOR)。 (2)打开游标(OPEN CURSOR)。 (3)提取游标(FETCH CURSOR)。 (4)根据需要,对游标中当前位置的行执行修改操作(更新或删除)。 (5)关闭游标(CLOSE CURSOR)。 (6)释放游标(DEALLOCATE CURSOR)。 DECLARE @NO char(6),@name varchar(50),@price varchar(50) DECLARE cur_goods scroll CURSOR FOR SELECT g_id,g_name,g_price FROM goods where g_status=促销 OPEN cur_goods fetch next from cur_goods into @NO,@name,@price print space(6)+----------商品信息表---------- print while @@fetch_status=0 begin print 商品号:+@no+商品名称:+@name+商品价格:+@price fetch next from cur_goods into @NO,@name,@price end print fetch last from cur_goods into @NO,@name,@price while @@fetch_status=0 begin print 商品号:+@no+商品名称:+@name+商品价格:+@price fetch relative -2 from cur_goods into @NO,@name,@price end close cur_goods deallocate cur_goods 【提示】 使用@price varchar(50)而不使用@price float便于接受数据并显示。 DECLARE CURSOR 定义 T-SQL服务器游标的属性,例如游标的滚动行为和用于生成游标所操作的结果集的查询。 OPEN 语句填充结果集。 FETCH 从结果集返回行。 CLOSE 语句释放与游标关联的当前结果集。 DEALLOCATE 语句释放游标所使用的资源。 事务 数据库系统的特点之一……数据共享,可以供多个用户使用。 在多用户使用的数据库中,同一时刻并行运行的事务可达数据百个,会产生多个事务同时存取同一数据的情况,若不加控制,则破坏数据库的一致性。例如:一个用户可以查看数据表中的数据,执行一些基于数据的查询操作。而另外一个用户在第一个用户查询期间更新了表,那么第一个用户第二次会看到不同的数据,造成第一次查询操作失效。 DBMS提供并发控制机制,通过对事务的执行过程进行控制来实现共享正确可靠的数据服务。 SQL Server 2005以事务为单位,使用锁来保证数据的一致性,并解决数据库操作时的并发问题; 1、事务的定义 事务是用户定义的数据库操作序列,这些操作可作为一个完整的工作单元。一个事务内的所有语句是一个整体,要么全部执行,要么全部不执行。 如在银行业务中,“从帐户A转移资金X到帐户B”就是一个典型的事务。这个事务可以分解为两个动作:(1)从账户A减去金额X。(2)在账户B中加上金额X。 事务是一个不可分割的工作逻辑单元,在SQL Server中应用事务来保证数据库的一致性和可恢复性。 在关系数据库中,一个事务可以是一条SQL语句、一组SQL语句或整个程序,一般地讲,一个程序中包含多个事务。 2、事务的特性:即ACID(每种属性英文名称的首字母缩写)属性。 (1)原子性(Atomicity):一个事务必须作为SQL Server工
文档评论(0)