欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > PPT文档下载  

    存储过程和游标.ppt

    • 资源ID:6111368       资源大小:253.49KB        全文页数:38页
    • 资源格式: PPT        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    存储过程和游标.ppt

    7.1存储过程概述,存储过程简介 SQL Server提供了一种方法:可以将一些预先编译的SQL语句集中起来由SQL Server数据库服务器来完成以实现某个任务,这就是存储过程。存储过程常驻在SQL Server数据库服务器的内存中。,存储过程优点,存储过程分类,存储过程的创建,使用Create procedure语句,CREATE PROC EDURE procedure_name parameter data_type VARYING=default OUTPUT,.n WITH RECOMPILE|ENCRYPTION|RECOMPILE,ENCRYPTION AS sql_statement,新存储过程的名称,过程中的参数,参数数据类型,参数的默认值,参数是返回参数,指定过程要执行的操作,过程中要包含的任意数目和类型的 Transact-SQL 语句,使用Create procedure语句,例1 创建存储过程,查询安徽表中所有内容,并按名字进行排序。CREATE PROCEDURE exp1asSelect*From 安徽Order by name,使用Create procedure语句,例2 创建存储过程,加入一条记录到安徽表中。CREATE PROCEDURE exp2ID int,AREA float,PERIMETER float,BNDRY_ID char(6),NAME char(8),DIQU char(8)asInsert into 安徽Valus(ID,AREA,PERIMETER,BNDRY_ID,NAME,DIQU),存储过程参数的使用,例3 创建带参数的存储过程,完成输入某一个字,输出包含该字的记录。CREATE PROCEDURE exp2name varchar(8)AsSelect*From 安徽Where NAME like%+name+%,存储过程参数的使用,例4 创建带参数的存储过程,完成输入某行政区划代码,如果存在输出该县(市)的信息,如果不存在,则显示“您输入错误!”CREATE PROCEDURE exp4BNDRY_ID varchar(8)AsBeginDeclare bit_exist bitIf exists(Select*From 安徽 Where BNDRY_ID=BNDRY_ID)Set bit_exist=1 else Set bit_exist=0 if bit_exist=1 Begin Select*From 安徽 Where BNDRY_ID=BNDRY_ID EndElsePrint 您输入错误!end,存储过程参数的使用,例5 创建带参数的存储过程,完成输入某行政区划代码前4位,统计该地区下辖县(市)有几个。CREATE PROCEDURE exp5BNDRY_ID varchar(8)AsSelect count(*)From 安徽 Where BNDRY_ID like BNDRY_ID+%,加密存储过程,如果用户不想让其他人查看存储过程的定义文本,可以在定义存储过程的同时,对其进行加密,来保护代码的安全性,通过加密的存储过程可以正常使用,但是无法查看该存储过程的内容,在SQL Server Management Studio中也不能修改,只能通过ALTER语句来修改。CREATE PROCEDURE exp6With encryptionasSelect*From 安徽Order by nameExec sp_helptext exp6,查看存储过程源代码,存储过程的维护,存储过程修改,ALTER PROC EDURE procedure_name parameter data_type VARYING=default OUTPUT,.n WITH RECOMPILE|ENCRYPTION|RECOMPILE,ENCRYPTION AS sql_statement,存储过程修改,ALTER PROCEDURE exp6asSelect distinct DIQU From 安徽,存储过程删除,使用命令删除存储过程,DROP PROC EDURE procedure_name,n,DROP PROCEDURE exp6,7.2 分行处理程序游标,在数据库开发过程中,使用SELECT语句查询,得到一个结果集,对这个结果集中的不同数据行,可能要做不同的处理。也就是要逐一处理每一个数据行。游标提供了一种比较好的解决方案。,7.2 分行处理程序游标,例 在图书表中查询出与数据库相关的图书,并对其中的部分书的价格进行调整。,7.2.2 使用游标,操作步骤:1.声明游标(变量)。2.打开游标。3.从一个游标中提取信息。4.关闭(释放)游标。,1.声明游标,语法格式:DECLARE SCROLL CURSORFOR FOR READ ONLY|UPDATE OF,.n,例7-15 声明只读游标。declare cur_c cursor for select 书名,作者,定价 from 图书 for read only例7-16 声明更新游标。declare cur_c cursor for select 书名,作者,定价 from 图书 for update,1.声明游标,2.声明游标变量,语法格式:DECLARE CURSOR建立游标变量与游标之间的关联。方法1:先声明游标和游标变量,然后用SET语句将游标赋给游标变量。例:DECLARE c1 CURSOR FOR SELECT*FROM s DECLARE cur_var CURSOR SET cur_var=c1,3.打开游标,游标声明后,如果要从游标中读取数据,必须打开游标。语法格式:OPEN GLOBAL|其中,GLOBAL表示要打开的是一个全局游标。,4.读取游标中的数据,当游标被打开后,就可以从游标中逐行地读取数据。语法格式:FETCH NEXT|PRIOR|FIRST|LAST|ABSOLUTE n|nvar|RELATIVE n|nvar FROM GLOBAL|INTO,.n,8.2.4.3 读取游标的数据(P207),Fatch next|prior|first|last absolute n|relative n from 游标名 into 变量名 Next-返回当前行的下一行记录Prior-返回紧邻当前行前面的结果行Last-返回最后一行记录Absolute n-返回第n行记录,当n为负值则从最后一行算起。Relative-游标当前位置起向后第n行,若n为负值则向前第n行。,游标的操作,Declare cur1 scroll cursor forSelect*from 图书Where 书名 like%数据库%Open cur1Fetch first from cur1Fetch last from cur1Fetch prior from cur1Fetch absolute 2 from cur1Fetch relative 2 from cur1Close cur1Deallocate cur1,(1)使用CLOSE命令关闭游标,处理完游标中数据后,必须关闭游标来释放数据结果集和定位于数据记录上的锁。语法格式:CLOSE GLOBAL|CLOSE 语句可以关闭游标,但不释放游标的数据结构。如果要再次使用游标,可用OPEN命令重新打开。,6.释放游标,用CLOSE命令关闭游标并没有释放游标占用的数据结构。使用DEALLOCATE命令将释放游标占用的数据结构,游标使用的任何资源也随之释放。语法格式:DEALLOCATE GLOBAL|游标的关闭指释放游标的结果集所占用的资源,游标的释放指释放游标占用的所有资源,当然也包括结果集占用的资源。,7.2 分行处理程序游标,例 在图书表中查询出与数据库相关的图书,并对其中的部分书的价格进行调整。Declare cur1 scroll cursor forselect 书名,作者,定价 from 图书where 书名 like%数据库%for update of 定价,7.2 分行处理程序游标,例 在图书表中查询出与数据库相关的图书,并对其中的部分书的价格进行调整。Declare cur1 scroll cursor forselect 书名,作者,定价 from 图书where 书名 like%数据库%for update of 定价Open cur1,7.2 分行处理程序游标,例 在图书表中查询出与数据库相关的图书,并对其中的部分书的价格进行调整。Declare cur1 scroll cursor forselect 书名,作者,定价 from 图书where 书名 like%数据库%for update of 定价Open cur1Fetch absolute 9 from cur1,7.2 分行处理程序游标,例 在图书表中查询出与数据库相关的图书,并对其中的部分书的价格进行调整。Declare cur1 scroll cursor forselect 书名,作者,定价 from 图书where 书名 like%数据库%Open cur1Fetch absolute 9 from cur1Update 图书 set 定价=30 where current of cur1,7.2.3 游标应用实例,1.用于游标的UPDATE语句的语法格式:UPDATE SET=|NULL|,n WHERE CURRENT OF 2.用于游标的DELETE语句的语法格式:DELETE FROM WHERE CURRENT OF,利用变量输出游标中的字段值,Declare S1 scroll cursor forSelect 姓名,班级,综合测评 from 学生Where 班级 like%地信%Declare sn intDeclare sc varchar(10)Declare ss varchar(10)Open S1Fetch absolute 4 from S into sn,sc,ssSelect sn,sc,ssClose S1Deallocate S1,利用游标修改数据库中的数据,Select 姓名,班级,综合测评 from 学生Declare S2 scroll cursor forSelect 姓名,班级,综合测评 from 学生Where 班级 like%地信%Open S2Fetch first from SUpdate 学生 set 姓名=modifybycursor where current of S2Close S2Deallocate S2,实例11:利用游标删除数据库中的数据,Select 姓名,班级,综合测评 from 学生Declare S3 scroll cursor forSelect 姓名,班级,综合测评 from 学生Where 班级 like%地信%Open S3Fetch absolute 3 from S3Delete from 职工 where current of S3Close S3Deallocate S3,使用fetch_status:该全局变量/配置函数返回被最后FETCH语句执行的游标的状态,返回类型为int:0:FETCH语句成功1:FETCH语句失败或此行不在结果集中2:被提取的行不存在,实例12:利用游标判断记录是否存在,Declare S4 scroll cursor forSelect 姓名,班级,综合测评 from 学生Where 班级 like%地信%Open S4 If fetch_status=0Print 存在该记录ElsePrint 不存在该记录Close S4,实例13:利用游标逐条显示数据库中的记录,Declare S5 scroll cursor forSelect 姓名,班级,综合测评 from 学生Where 班级 like%地信%Open S5While fetch_status=0BeginFetch next from S5EndClose S5Deallocate S5,例8-20 将地信班中2003级的综合测评成绩上浮5%。DECLARE c CHAR(4),g CHAR(4),s doubleDECLARE S6 CURSORFORSELECT 班级,年级,综合测评FROM 学生Where 班级 like%地信%,7.2.3 游标应用实例,OPEN S6FETCH NEXT FROM S6 INTO c,g,sWHILE fetch_status=0BEGINIF g like 2003UPDATE 学生SET 综合测评=综合测评*(1+0.05)WHERE CURRENT OF S6FETCH NEXT FROM S6 INTO c,g,sENDCLOSE S6DEALLOCATE S6GO,7.2.3 游标应用实例,

    注意事项

    本文(存储过程和游标.ppt)为本站会员(小飞机)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开