- 1、本文档共66页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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 由于下列关系表
您可能关注的文档
- 过程性考试多选.doc
- 审计学第九章.doc
- 高一数学全集和补集.ppt
- 《审计学》考试试题A卷.doc
- 第二章 账户与复式记帐.ppt
- 审计学试卷C 及其参考答案.doc
- CPA审计模拟试题三(附答案).doc
- 第三章 AIS开发.ppt
- 美国专利数据库.ppt
- 第一讲绪论晶体结合能-11.ppt
- 岸基供电系统 第4部分:工频电源.pdf
- 人教版八下英语Unit 5 What were you doing when the rainstorm came_测试卷.docx
- 热带作物品种区域试验技术规程 木薯.pdf
- 草原防火阻隔带建设技术规程.pdf
- 渔用气胀救生筏技术要求和试验方法-.pdf
- 浙江省杭州市2024-2025学年八年级下学期期中考试英语试卷(含答案).docx
- 重庆市渝北区六校联盟2024-2025学年九年级下学期期中教学大练兵语文试卷.docx
- 食品安全-花椒籽油 (2).pdf
- 2025年海博思创分析报告:储能集成“小巨人”,国内外业务进展可期.pdf
- 地理标志产品 宽城板栗.pdf
文档评论(0)