05第五章数据库编程.ppt

  1. 1、本文档共66页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
05第五章数据库编程

第5章 数据库编程 5.1 存储过程的创建与管理 5.2 函数的创建与管理 5.3 触发器的创建与管理 5.4 游标的创建和管理 5.5 应用实例分析 5.1 存储过程的创建与管理 5.1.1 创建和执行存储过程 5.1.2 管理存储过程 5.2 函数的创建与管理 5.2.1 创建和执行函数 5.2.2 管理函数 5.3 触发器的创建与管理 5.3.1 DML触发器 5.3.2 DDL触发器 5.3.3 管理触发器 5.4 游标的创建与管理 5.4.1 使用游标的步骤 5.4.2 游标定位修改和删除操作 5.4.1使用游标的步骤 DECLARE 声明游标 OPEN打开游标 从一个游标中FETCH信息 CLOSE关闭游标 DEALLOCATE释放游标 ?例如以下执行过程: (1)声明一个游标 (2)打开游标 (3)读取游标 (4)BEGIN TRANSATION (5)数据处理 (6)COMMIT TRANSATION (6)回到步骤(3) 5.4.2 游标定位修改和删除操作 如果在声明游标时使用了FOR UPDATE语句,那么就可以在UPDATE或DELETE命令中以WHERE CURRENT OF关键字直接修改或删除当前游标中当前行的数据。当改变游标中数据时,这种变化会自动地影响到游标的基础表。但是如果在声明游标时选择了INSENSITIVE选项时,该游标中的数据不能被修改。 语法格式: 游标定位修改UPDATE语句的格式如下 UPDATE 表名 SET 子句 WHERE CURRENT OF {{[GLOBAL] 游标名} |游标变量} 游标定位删除DELETE语句的格式为如下 DELETE FROM 表名 WHERE CURRENT OF {{[GLOBAL] 游标名} |游标变量} 将sno等于S060109的记录smtel改城市改为天津 SET NOCOUNT ON DECLARE @sno CHAR(7), @sname CHAR(10),@mtel CHAR(11), @scity CHAR(10) DECLARE stu_up_cur cursor FOR SELECT sno,sname,smtel,scity FROM student FOR UPDATE OF smtel,scity OPEN stu_up_cur FETCH NEXT FROM stu_up_cur INTO @sno, @sname,@mtel, @scity WHILE @@fetch_status=0 BEGIN SELECT @sno, @sname,@mtel, @scity IF @sno=S060109 UPDATE student SET smtelscity=天津 WHERE CURRENT OF stu_up_cur FETCH NEXT FROM stu_up_cur INTO @sno, @sname,@mtel, @scity END CLOSE stu_up_cur DEALLOCATE stu_up_cur 5.5 应用实例分析 DECLARE @tb_exist INT SET @tb_exist=0 IF EXISTS(SELECT * FROM sysobjects WHERE name=Enrollment AND xtype=U) SET @tb_exist=@tb_exist | 1 IF EXISTS(SELECT * FROM sysobjects WHERE name=Offering AND xtype=U) SET @tb_exist=@tb_exist | 2 IF EXISTS(SELECT * FROM sysobjects WHERE name=Student AND xtype=U) SET @tb_exist=@tb_exist | 4 IF EXISTS(SELECT * FROM sysobjects WHERE name=Course AND xtype=U) SET @tb_exist=@tb_exist | 8 IF EXISTS(SELECT * FROM sysobjects WHERE name=Teacher AND xtype=U) SET @tb_exist=@tb_exist | 16 IF @tb_exist !=31 BEGIN --有一些表不存在 PRINT 由于下列关系表

文档评论(0)

6358999 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档