Oracle Forms中多用途代码有哪些? (oracle是什么)

技术教程 2025-05-04 08:42:44 浏览
oracle是什么

在前几年,当Oracle数据库放弃相关客户端OracleForms的时候,随之也跟着消失的那些相关内置的某些函数中会有一项是关于函数(alert message function)传递参数的。如果你处理错误或者缺失的输入参数。

Forms迁移过程的一部分是将这个内置的函数从6i版本改成9i版本。

Forms中多用途代码有哪些

复杂的应用可能包含有上千条警告消息,并且一个主要的应用(即Forms)的变化会导致上千条改变。做这样的改变的确是一件讨人嫌的行为。

另一方面,作为一个使用PL/SQL的DBA和程序员,你到底写过多少次DBMS_OUTPUT.PUT_LINE(”)?必须写的或者敲入的DBMS_OUTPUT.PUT_LINE变得非常无聊,使用方便的、内置的短小的代码不是更好吗?

可能并不是经过深思熟虑,但是更多的归咎于好运或者意识到同样的东西必须敲一遍又一遍的现实,机灵的OracleForms程序员们创建了自己的内置函数,采用了过程的方式来产生警告消息。相同的原理可以被用在你日常的PL/SQL代码中。事实上,你可以创建一个小的消息库管理很多类型的输出消息。让我们看看一些这样的可能性。

一个简单的警告消息过程

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

另一个版本可以处理字符串类型,因此对 “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类型。

你的确必须做这样的转换吗?不,但是为了和你已有的保持一致,如果你在别的地方做了类型映射,那么这里也进行类型映射。不管这些,下面的例子显示了第一种方法的灵活性。

Oracle

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

好了,这次输出本可以看起来更好一些(注意输出中msg1和msg2中没有空格)。我们到这里就必须格式化一个或者全部两个消息输入让输出好看一些。然而,假如美观不需要关心,那么创建基于像 (‘dupes ‘,46)这样的输入的消息,这样做也是非常简单的,虽然你需要处理空格或者格式化。

那么这种方法是否有缺陷呢?这就看情况了。假如你需要的仅仅是msg1,而不需要msg2,怎么办?当创建这个过程,需要允许msg2是null值。显然,msg1不需要这样,对吧

【编辑推荐】


大家都建议mysql和jsp页面的编码使用utf-8,可是插入数据怎么办?

你好,先回答下你的问题,通过sql是不行的,你要这么做的时候设置你的连接方式,如下:String url = jdbc:mysql://127.0.0.1:3306/jeesite?useUnicode=true&characterEncoding=utf-8Connection conn= (url);2.设置mysql字符集为utf-8mysql和jsp页面的编码使用utf-8是十分对的, 要这么做的理由如下:统一字符编码可以避免字符乱码,利于国际化.还有,一般情况下,这个不是建议.是规范哦3,你要确定你的jsp页面是utf-8哦,看有没有加上<%@ page contentType=text/html;charset=UTF-8 %>4,form表单提交的时候用 post方式 尽量. 还有 以URL方式提交的时候, 我记得有个URLEncoding的API的 如果你提交的参数是汉字的,必须用这个API转换为汉字.5,乱码解决,必须选判断出jsp到servlet(jsp)的时候就乱码了,还是插入的时候乱码了...大晚上的 洋洋洒洒一百多字 纯手打 就给分哦....

程序中如何删除表 就是用代码删除数据库中的表

不知你用的是什么环境,我用VFP来解释下。 数据库中的表是不能直接删除的。 要想删除,先把这个表移出数据库,然后再删除。 命令你可以查一下。 (好象移出是:remove table 表名;删除表:del file 表。 你核实一下,有些忘了。 )

C# vs winfrom连接access数据库代码 增删改查

程序代码: using ; using ; string strConnection=Provider=.4.0;; strConnection+=@DataSource=C:\BegASPNET\; OleDbConnection objConnection=new OleDbConnection(strConnection); (); (); 解释: 连接Access数据库需要导入额外的命名空间,所以有了最前面的两条using命令,这是必不可少的! strConnection这个变量里存放的是连接数据库所需要的连接字符串,他指定了要使用的数据提供者和要使用的数据源。 “Provider=.4.0;”是指数据提供者,这里使用的是Microsoft Jet引擎,也就是Access中的数据引擎,就是靠这个和Access的数据库连接的。 “Data Source=C:\BegASPNET\”是指明数据源的位置,他的标准形式是“Data Source=MyDrive:MyPath\”。 PS: 1.“+=”后面的“@”符号是防止将后面字符串中的“\”解析为转义字符。 2.如果要连接的数据库文件和当前文件在同一个目录下,还可以使用如下的方法连接: strConnection+=Data Source=; strConnection+=MapPath(); 3.要注意连接字符串中的参数之间要用分号来分隔。 “OleDbConnection objConnection=new OleDbConnection(strConnection);”这一句是利用定义好的连接字符串来建立了一个链接对象,以后对数据库的操作我们都要和这个对象打交道。 “();”这用来打开连接。 至此,与Access数据库的连接完成。

本文版权声明本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,请联系本站客服,一经查实,本站将立刻删除。

发表评论

热门推荐