- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
* * * * * * * * * * * * * * * * * * * * * * * * * * 注:学术界对于如何界定错误和异常有不同争论,我们这里认为,各种非正常的状态称为错误,而异常是错误处理的一种机制。 一般地说,计算机程序必须能够处理错误,因为有正常的情况,就有不正常的情况,不能处理这种状态的程序是不可靠的,不够“鲁棒”。 * A:返回值。我们常用函数的返回值来标志成功或者失败,甚至是失败的原因。但是这种做法最大的问题是如果调用者不主动检查返回值也是可以被编译器接受的,你也奈何不了它。这在C++中还导致另外一个问题,就是重载函数不能只有不同的返回值,而有相同的参数表,因为如果调用者不检查返回值,则编译器会不知道应该调用哪个重载函数。 B:全局状态标志。例如系统调用使用的errno。返回值不同的是,全局状态标志可以让函数的接口(返回值、参数表)被充分利用。函数在退出前应该设置这个全局变量的值为成功或者失败(包括原因),而与返回值一样,它隐含的要求调用者要在调用后检查这个标志,这种约束实在是同样软弱。全局变量还导致了另外一个问题,就是多线程不安全:如果多个线程同时为一个全局变量赋值,则调用者在检查这个标志的时候一定会非常迷惑。如果希望线程安全,可以参照 errno的解决办法,它是线程安全的。 * * * * * * * * * * * * * 维护触发器 ALTER TRIGGER 触发器名 [ENABLE | DISABLE | COMPILE ]; DROP TRIGGER 触发器名; 在触发器中出现异常时,所有工作被卷回。 不能读取、修改正在变化的表。不能修改完整性约束引用的表的主键、外键和唯一值。 触发器使用限制 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。 视图触发器 * * * * * * * * * * * * * * * * * * * * * * * * * * * IN OUT IN OUT 指定 缺省类型 作用 传递参数 传送返回值 传送参数和返回值 形式参数 如同一个常数 未初始化变量 已初始化变量 不能赋值 不能用于表达式、必须赋值 应该赋值 实际参数 可以是常量、变量、表达式 变量 变量 传递方式 值传
您可能关注的文档
最近下载
- 吉林省中药软片炮制规范.pptx VIP
- 名著阅读《湘行散记》七年级语文上册部编版(共9页).docx VIP
- 《白洋淀纪事》阅读测试题含答案(推荐).docx VIP
- 必考名著《白洋淀纪事》导读+知识点汇总.pdf VIP
- CQJZDE-2008 重庆市建筑工程计价定额.docx VIP
- 人教部编版七年级语文上册名著选读《湘行散记》导读.doc VIP
- 重庆市建筑工程计价定额CQJZDE-2008.doc
- 部编版七上语文名著导读《朝花夕拾》、《白洋淀纪事》、《湘行散记》知识点练习(含答案).docx VIP
- 超星尔雅学习通《大学生劳动教育》章节测试含答案.docx VIP
- 七年级上册名著《湘行散记》知识点+习题(共12页).docx VIP
文档评论(0)