数据库应用不技术教程第五章面向过程的sql扩展.pptVIP

数据库应用不技术教程第五章面向过程的sql扩展.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
* * * * * * * * * * * * * * * * * * 注:学术界对于如何界定错误和异常有不同争论,我们这里认为,各种非正常的状态称为错误,而异常是错误处理的一种机制。 一般地说,计算机程序必须能够处理错误,因为有正常的情况,就有不正常的情况,不能处理这种状态的程序是不可靠的,不够“鲁棒”。 * A:返回值。我们常用函数的返回值来标志成功或者失败,甚至是失败的原因。但是这种做法最大的问题是如果调用者不主动检查返回值也是可以被编译器接受的,你也奈何不了它。这在C++中还导致另外一个问题,就是重载函数不能只有不同的返回值,而有相同的参数表,因为如果调用者不检查返回值,则编译器会不知道应该调用哪个重载函数。 B:全局状态标志。例如系统调用使用的errno。返回值不同的是,全局状态标志可以让函数的接口(返回值、参数表)被充分利用。函数在退出前应该设置这个全局变量的值为成功或者失败(包括原因),而与返回值一样,它隐含的要求调用者要在调用后检查这个标志,这种约束实在是同样软弱。全局变量还导致了另外一个问题,就是多线程不安全:如果多个线程同时为一个全局变量赋值,则调用者在检查这个标志的时候一定会非常迷惑。如果希望线程安全,可以参照 errno的解决办法,它是线程安全的。 * * * * * * * * * * * * * * * * * CREATE OR REPLACE TRIGGER audit_emp AFTER INSERT OR UPDATE OR DELETE ON emp FOR EACH ROW DECLARE time_now DATE; terminal CHAR(10); BEGIN time_now := SYSDATE; -- 得到当前时间 IF INSERTING THEN --记录新的主键 INSERT INTO audit_table VALUES (audit_seq.NEXTVAL, user, time_now, EMP, INSERT, :new.empno); ELSIF DELETING THEN --记录删除行的主键 INSERT INTO audit_table VALUES (audit_seq.NEXTVAL, user, time_now, EMP, DELETE, :old.empno); ELSE --记录更新行的主键 INSERT INTO audit_table VALUES (audit_seq.NEXTVAL, user, time_now, EMP, UPDATE, :old.empno); 触发器举例 IF UPDATING (‘SAL’) THEN --记录sal的新旧值 INSERT INTO audit_table_values VALUES (audit_seq.CURRVAL, SAL, :old.sal, :new.sal); ELSIF UPDATING (DEPTNO) THEN --记录deptno的新旧值 INSERT INTO audit_table_values VALUES (audit_seq.CURRVAL, DEPTNO, :old.deptno, :new.deptno); END IF; END IF; END; 触发器举例 对视图进行DML时触发,可以完成替代性的DML操作。 不检查视图的CHECK约束。 无需指定BEFORE或AFTER,对于修改,无需指定列。一定是FOR EACH ROW。 视图触发器 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 5.5 游标 游标的作用 使用游标 游标FOR循环 游标属性 修改游标中数据 游标的作用 用来处理从数据库中查询出来的一组数据的机制。 游标查询返回的数据称为结果集(result set)。 游标的使用类似文件操作,包括OPEN、FETCH、CLOSE等操作。 游标的类型 显式游标 隐含游标 PL/SQL为每一个DML语句隐含定义了一个游标 包游标 使用游标 声明 在DECLARE段 打开 循环读取 读取当前行的数据到变量中 判断是否读到末尾 关闭 关闭后才可以重新打开 游标声明 声明 CURSOR 游标名 [(参数列表)] [RETURN

文档评论(0)

181****7126 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档