文章分类 | 推荐文章 | 最新文章 | 热点文章 | 最新软件 | 国产软件 | 国外软件 | 汉化补丁 | 设为首页 | 加入收藏
业界资讯 | 图形图像 | 操作系统 | 网络冲浪 | 工具软件 | 办公软件 | 媒体动画 | 精文荟萃 | 认证考试 | 网站建设 | 技术开发 | 专栏
当前位置:abcdown网络学院程序开发Oracle解析Oracle/Oracle Forms 的多用途代码
精品广告
推荐TOP10
·常用数据库比较
·ODBC API常用函数诠释
·提高ORACLE数据库的查询统计速度
·细化解析:Oracle使用的hints调整机制
·解析Oracle/Oracle Forms 的多用途代码
·从Oracle的FORM中调用REPORT的实用技巧
·Oracle SQL精妙SQL语句讲解
·ORACLE学习笔记--性能优化四
·ORACLE常用傻瓜问题1000问
·ORACLE常见错误代码的分析与解决之二
阅读TOP10
·详细介绍ORACLE sqlplus命令
·ORACLE中LONG类型字段的存取
·PL/Sql循序渐进全面学习教程
·Oracle SQL精妙SQL语句讲解
·破解Oracle中国高层频繁变动之谜
·ORACLE数据库傻瓜手册
·监控Oracle数据库的常用shell脚本
·ORACLE常用傻瓜问题1000问
·细化解析:Oracle使用的hints调整机制
·ORACLE傻瓜手册长篇连载

解析Oracle/Oracle Forms 的多用途代码

日期:2007年8月31日 作者: 查看:[大字体 中字体 小字体]


几年前,当Oracle放弃客户端的Forms的时候,随之消失的那些内置的函数中有一项是关于向警告消息函数(alert message function)传递参数。如果你处理错误或者缺失的输入参数(你应该这么做),Forms迁移过程的一部分是将这个内置的函数从6i版本改成9i版本。复杂的应用可能包含有上千条警告消息,并且一个主要的应用(即Forms)的变化会导致上千条改变。做这样的改变的确是一件讨人嫌的行为。


另一方面,作为一个使用PL/SQL的DBA和程序员,你到底写过多少次DBMS_OUTPUT.PUT_LINE('')?必须写的或者敲入的DBMS_OUTPUT.PUT_LINE变得非常无聊,使用方便的、内置的短小的代码不是更好吗?可能并不是经过深思熟虑,但是更多的归咎于好运或者意识到同样的东西必须敲一遍又一遍的现实,机灵的Forms程序员们创建了自己的内置函数,采用了过程的方式来产生警告消息。相同的原理可以被用在你日常的PL/SQL代码中。事实上,你可以创建一个小的消息库管理很多类型的输出消息。让我们看看一些这样的可能性。

一个简单的警告消息过程

就像在这一章节标题中表示的那样,第一个方法是非常简单的。假设你有一个常见的需求要输出某个过程、函数或者代码块更新的记录个数。让我们假定被更新行的个数是46。使用下面的过程之后,一个简单的“am(46);”语句就可以你需要的输出:

CREATE OR REPLACE procedure am (msg number)
as begin dbms_output.put_line
('Records updated: 'msg); end; /

另一个版本可以处理字符串类型,因此对 “ams('your message here');”的调用显著的降低了你敲入的次数。当调试或者解决问题的代码中,有这样一个简单的内置函数对输出“where am I in the code”的语句是非常宝贵的。位置报告可以确认,比如,你进入了IF-THEN-ELSE语句中哪个分支。假如你的问题代码调用了很多次其他的对象(过程、函数等等),输出像“calling function X”或者“returned from function X”这样的状态信息可以确认过程流。最终,另外一种使用情况是报告数值。你可以报告或者跟踪一个变量的值是如何被改变的。

建立一个警告消息库

当然,你的消息库的复杂性和灵活性完全取决于你。假如你的(输出)消息是简单的,那么保持函数过程简单。更准确的讲,保持函数过程的个数是最少的。只要两个简单的过程,ams和amn,就可以用来输出基于字符串和数值的消息了。

假如你需要让输出的文字内容根据运算的输出有所变化,比如DML语句的输出,那么你可能需要三个新的内置过程(插入、更新和删除运算各一个)。可能你想说明删除的类型或者原因。比如一个批处理作业的某一步是计算重复记录的个数。那么像“Records counted: 46” 这样的输出是足够有用的,但是在这种情况下,“Duplicates counted: 46”会显得更有效。因此,我们增加了2个新的内置过程。

这样,我们现在有了至少6个不同的过程。现在,管理性的问题应该比较明显了。我们寻找一些简单的,但是同时又是健壮的过程。至少有两种方式可以用于重新简化需要的功能。一种方法是让警告消息过程能够接收两个输入参数。另外一种方法,正是我准备介绍的,是把这些过程打包。

增加输入参数的个数

再说一遍,假如前面的简单方法可以满足了你的要求,那么就没必要继续深入了。创建有两个输入参数的过程,第一个参数是消息文字或者说基础,第二个参数可以是输出、位置、状态或者数值。如果你关注数据类型的转化,那么这两个输入参数的组合text/text和text/number都可以统一成text/text类型。你的确必须做这样的转换吗?不,但是为了和你已有的保持一致,如果你在别的地方做了类型映射,那么这里也进行类型映射。不管这些,下面的例子显示了第一种方法的灵活性。

CREATE OR REPLACE procedure am
(msg1 varchar2, msg2 varchar2)
as begin dbms_output.put_line(msg1msg2); end; /

编译之后,下面是使用的例子。

SQL> set serveroutput on SQL> exec am

[1] [2] [3] 下一页 

上一篇:解析SQL语句中INSERT语句的另一种写法

下一篇:设计理论:信息可视化与视觉设计


相关软件: 相关文章:
·PhotoShop使用技巧
·截拳道视频教材 RM 著名截拳道技击家石天龙示范 实用!
·组策略在 Windows 2000 和 Windows 2003 中的应用
·星际争霸及母巢之战v1.12b升级档通用破解免CD补丁及所有战网连接补丁
·绘声绘影10汉化版 iso 最新试用
·目前中国最快最好用的XP系统 天宇7.5版美化GHOST XP
·三角洲3大地勇v1.00.31升级档破解版(硬盘版专用)
·侵入最大的六合彩论坛系统---六合专用BBS
·色谜语256个 有答案!网上泡MM你肯定用得着
·女孩起名常用字
·乳房太重要了作用太大了:你的乳房让谁摸了
·一影楼用女学生裸体写真作宣传(图)
·流光5.0使用小窍门
·常用英文名字排行榜

特别声明:本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
[打印本页] [关闭窗口] 转载请注明来源:http://www.abcdown.net
首页 | 本站声明 | 下载帮助 | 发布软件 |
中文版权所有:ABC学院 浙ICP备05000717号