目录搜索
oracle知识ORACLE的数据类型Oracle技术网—DBMS_Job包的用法Oracle技术网—Oracle for NT系统实用工具介绍Oracle技术网—Oracle常见错误代码Oracle技术网—Oracle常用ScriptOracle技术网—Oracle常用数据字典Oracle技术网—ORACLE数据库简介Oracle技术网—Oracle特殊包Oracle技术网—Oracle相关站点Oracle技术网—哪些初始化参数最影响Oracle系统性能PL/SQLDBAOracle7 7.3.2.2Oracle技术网—listener.log的内容增长很快,是否可以删除重建Oracle技术网—ORACLE表空间恢复方案Oracle技术网—Oracle常用系统文件有哪些Oracle技术网—ORACLE回滚段管理(上)Oracle技术网—ORACLE回滚段管理(下)Oracle技术网—Oracle如何决定使用哪个回退段Oracle技术网—Oracle数据库的空间管理技巧Oracle技术网—Oracle数据库碎片整理Oracle技术网—Oracle数据库有哪几种关闭方式Oracle技术网—Oracle数据库有哪几种启动方式Oracle技术网—Oracle预定义角色有哪些Oracle技术网—ROLLBACK不能回滚的命令Oracle技术网—查看哪些session正在使用哪些回滚段Oracle技术网—存储参数(storage子句)含义及设置技巧Oracle技术网—和权限有关的表有哪些Oracle技术网—漫谈数据库的启动和关闭Oracle技术网—哪些初始化参数最影响Oracle系统性能Oracle技术网—如何备份控制文件Oracle技术网—如何查出前台正在发出的sql语句Oracle技术网—如何查看Oracle版本及安装了哪些选项Oracle技术网—如何查看Oracle数据表的建表语句Oracle技术网—如何查看SGA区剩余可用内存Oracle技术网—如何查看各个表空间占用磁盘情况Oracle技术网—如何查看后台进程Oracle技术网—如何查看什么时间有哪些数据库对象结构被修改过Oracle技术网—如何查看数据库的各种数据文件Oracle技术网—如何查看数据库的字符集Oracle技术网—如何查看数据文件是否自动扩展Oracle技术网—如何查看数据文件所在的路径Oracle技术网—如何查看用户表上的约束内容Oracle技术网—如何查看用户表所占空间的大小Oracle技术网—如何查询出primary key和forgen key的关系表Oracle技术网—如何改变当前联机日志文件的大小Oracle技术网—如何利用DBMS_SQL包和游标计算当前用户下所有表的行数Oracle技术网—如何启动ARCHIVELOG模式Oracle技术网—如何取出某一用户的密码,再原封不动的改回去Oracle技术网—如何设置BLOCK_SIZE大于2K,如:4K、16KOracle技术网—如何手工指定使用哪个回退段Oracle技术网—如何修改internal的口令Oracle技术网—如何移动控制文件到新的目录中Oracle技术网—如何移数据库文件Oracle技术网—如何增加表空间的大小Oracle技术网—怎样查看init.ora文件Oracle技术网—怎样查看SGA值Oracle技术网—怎样查看哪些用户拥有SYSDBA、SYSOPER权限?Oracle技术网—怎样快速查出Oracle 数据库中的锁等待Oracle技术网—怎样识别IO竞争和负载平衡Exp vs ImpOracle技术网—EXP、IMP 命令详解Oracle技术网—Exp/Imp大量数据Oracle技术网—Export/Import 使用技巧与常见错误Oracle技术网—Oracle数据库的备份与恢复Oracle技术网—如何把数据exp到Sql loader里Oracle技术网—如何单独备份一个或多个表Oracle技术网—如何单独备份一个或多个用户Oracle技术网—如何导入指定表Oracle技术网—如何建立一个与现存数据库相同,但不包含数据的空库Oracle技术网—如何在oracle7和oracle8之间exp/imp数据Oracle技术网—提高ORACLE数据库系统import性能Oracle技术网—为何我的导出文件只有500KOracle技术网—自动备份Oracle数据库Oracle技术网—作Export或Import时,如何记录LOG信息?SQL技巧Oracle技术网—LONG数据类型使用上的一些说明Oracle技术网—Oracle8 PL/SQL编程风格与系统性能的提高Oracle技术网—Oracle8中用户名、表名、列名、索引名...可以用中文命名吗Oracle技术网—Oracle中如何实现某一字段自动增加1Oracle技术网—SQL(Structured Query Language)语句分哪几类Oracle技术网—SQL*PLUS常用命令列表Oracle技术网—SQL*Plus系统环境变量有哪些?如何修改?Oracle技术网—SQL*Plus中缓冲区命令列表Oracle技术网—SQL*Plus中能运行哪几种命令Oracle技术网—SQLPlus中的复制和粘贴技巧Oracle技术网—查看本用户下的各种对象的SQL脚本Oracle技术网—查找a表中有,而在b表中没有的记录Oracle技术网—利用PL/SQL打印ASCII表Oracle技术网—如何查找、删除表中重复的记录Oracle技术网—如何对CLOB行字段执行全文检索Oracle技术网—如何对CLOB字段进行全文检索?Oracle技术网—如何改变表中列的名字Oracle技术网—如何改变一个字段初始定义的Check范围Oracle技术网—如何给表、列加注释Oracle技术网—如何将 primary key 建在其它的表空间上Oracle技术网—如何删除表中的列Oracle技术网—如何使‘CREATE TABLE AS SELECT’能支持ORDER BY ?Oracle技术网—如何通过 SQL*PLUS 将符号 & 、'号(单引号) 插入Oracle数据库的表中Oracle技术网—如何用SQL生成SQL批处理文件Oracle技术网—如何在PL_SQL中读写文件Oracle技术网—如何自动生成一个含有20000101至20500101共50年日期的表Oracle技术网—如何自动生成一个含有2000年01月至2050年01月共50年月份的表Oracle技术网—删除a表中和b表相同的数据Oracle技术网—在Oracle快速进行数据行存在性检查Oracle技术网—怎样查看表的结构Oracle技术网—怎样改变SQL*Plus启动时默认路径Oracle技术网—怎样计算表中的记录数Oracle技术网—怎样在SQL*Plus中使用 '&' 来实现自定义参数变量?Oracle技术网—怎样在查询记录时给记录加锁Oracle错误Oracle7 7.3.2.2Oracle技术网—Oracle 816中如何启动Enterprise ManagerOracle技术网—Oracle Enterprise Manager(OEM)工具中如何以SYSOPER、SYSDBA方式登录Oracle技术网—ORACLE数据库应用开发常见问题及排除Oracle技术网—监听器错误Oracle技术网—联机热备份失败后,如何打开数据库Oracle技术网—没有备份、只有归档日志,如何恢复数据文件Oracle技术网—某个数据文件损坏,如何打开数据库Oracle技术网—如何使用归档日志进行完全恢复Oracle技术网—如何正确建立TYPE、partition(分区)Oracle技术网—一个控制文件被损坏,如何启动Oracle技术网—在SQL*Plus中insert进的都是中文的,为什么一存入服务器后,再select出的就是???了Oracle技术网—重装Oracle服务器后,以前的数据可以恢复吗Oracle初学者入门Oracle技术网—Oracle 8.1.6 for Win2000 系统文件解释Oracle技术网—Oracle 基本知识Oracle技术网—Oracle8 数据类型Oracle技术网—what is sql?Oracle技术网—安装、配置后,SQL*Plus操作初步Oracle技术网—安装Oracle后,经常使用的修改表空间的SQL代码Oracle安装、删除Oracle技术网—Oradim工具的用法Oracle技术网—WINDOWS NT上,如何删除ORACLE SERVICEOracle技术网—如何连接两台Oracle服务器Oracle技术网—如何在Windows 2000下将Oracle完全卸载Oracle技术网—如何在WINDOWS NT上删除所有的Oracle安装?Oracle技术网—手工安装数据库时需要安装那些系统包Oracle技术网—手工创建数据库的全部脚本及说明Oracle安全性问题Oracle技术网—Linux ORACLE 8.1.5漏洞Oracle技术网—Oracle 8.1.6的oidldapd中的漏洞Oracle技术网—Oracle8的不安全因素及几点说明Oracle技术网—Oracle数据库的安全策略Oracle技术网—Oracle数据库密码文件的使用和维护Oracle技术网—提高Oracle数据库应用系统安全的举例与分析数据库安全性策略Oracle系统设置、优化、连接《Oracle8 优化技术》摘录 (第一章 安装)《Oracle8 优化技术》摘录 (第二章 内存/CPU)《Oracle8 优化技术》摘录 (第三章 输入/输出)Oracle技术网—ASP 中通过OLEDB访问 Oracle 的代码Oracle技术网—Delphi5 企业版使用BDE访问 Oracle方法Oracle技术网—oracle database access objectOracle技术网—Oracle基于Client/Server的性能调整Oracle技术网—PB7 连接 Oracle 的配置方法Oracle技术网—PB内置Oracle数据库接口的使用方法Oracle技术网—PHP+Oracle(OCI) 初步Oracle技术网—PHP4连接Oracle 8i的方法(转译)Oracle技术网—多个数据库时,如何设置默认数据库Oracle技术网—如何备份Oracle设置Oracle技术网—如何让你的SQL运行得更快Oracle技术网—如何修改 SQL*Plus 的启动参数Oracle技术网—如何在Windosws 2000中安装JSP并访问OracleOracle技术网—如何在Windosws 2000中安装perl并访问OracleOracle技术网—如何在Windosws 2000中安装PHP4并访问OracleOracle技术网—如何在Windosws NT中使用批处理命令自动启动或关闭Oracle ServicesOracle技术网—如何在客户端省略输入数据库串,而只输入用户名、密码即可Oracle技术网—使用Database Configuration Assistant安装第二个数据库Oracle技术网—修改Oracle7数据库maxdatafiles参数的方法索引、序列、快照、数据库链路、触发器Oracle技术网—触发器的几种应用Oracle技术网—建立触发器时最容易忽略的两个地方Oracle技术网—快照和触发子结合使用的例子Oracle技术网—能否通过视图更新表中的数据Oracle技术网—如何创建一个简单的JAVA存储过程?Oracle技术网—如何创建隐藏IP地址的最后一项的函数?Oracle技术网—如何加密Oracle中的存储过程Oracle技术网—为什么有时ORACLE数据库不用索引来查找数据Oracle技术网—我的数据库链路为什么不工作Oracle技术网—一个建立快照的简单例子Oracle技术网—怎样创建一个简单的自定义过程并引用Oracle技术网—怎样手工刷新快照oracle与其他数据库的比较MySQL 测试Oracle技术网—Oracle 和 mysql 的一些简单命令对比参照Oracle技术网—Oracle8i和Microsoft SQL Server7.0比较Oracle技术网—比较SQL Server与Oracle、DB2Oracle技术网—各种数据类型的比较Oracle技术网—戏说SQL—几种SQL 服务器的比较关键任务      在Internet上运作公司是一项艰苦的任务其它知识OEM常见问题及其解决办法Oracle 8 资料库函式库Oracle 资料库函式库Oracle技术网—Decode()函数使用技巧(NT+IIS+ASP+ORACLE)Oracle技术网—Dual伪列Oracle技术网—NULL 使用详解Oracle技术网—OLAP及其多维数据分析Oracle技术网—Oracle for NT系统实用工具介绍Oracle技术网—ORACLE 用户的规范化管理Oracle技术网—user、uid伪列Oracle技术网—大型数据库设计原则Oracle技术网—留言簿(带Oracle数据库分页的显示功能)Oracle技术网—漫谈oracle中的空值Oracle技术网—如何正确利用Rownum来限制查询所返回的行数Oracle技术网—什么是ROWID,为什么需要它Oracle技术网—数据库技术考试大纲(中级)Oracle技术网—数据库行业的现状和展望Oracle技术网—在客户端处理Oracle的数据行加锁问题如何对CLOB行字段执行全文检索Developer 2000Oracle技术网—Developer/2000中各键盘触发子所对应的“按键”Oracle技术网—FORM调用REPORT时,如何去掉report serverOracle技术网—FORM中,Exception(例外)都有哪些,如何书写Oracle技术网—FORM中,FORM中,如何引入图像Oracle技术网—FORM中,WINDOW标题的设置Oracle技术网—FORM中,常用快捷键有哪些Oracle技术网—FORM中,触发子exit_form的两种功能是什么Oracle技术网—FORM中,当光标走到块的最后一项时,如何让按“enter回车”键时,光标自动走到下一条记录的第一项?Oracle技术网—FORM中,当用鼠标点击标签画布的某一“标签页”时,如何判断点击的是哪一页Oracle技术网—FORM中,如何屏蔽默认的功能键Oracle技术网—FORM中,如何实现屏幕同步刷新?Oracle技术网—FORM中,如何使用警告Oracle技术网—FORM中,如何通过 ODBC 访问 Acress 数据?Oracle技术网—FORM中Oracle技术网—FORM中,设置应用特性(光标类型)Oracle技术网—FORM中,怎样创建动态下拉列表ListOracle技术网—FORM中如何存取声音Oracle技术网—FORM中如何存取图象?如何把图象从一个表中导到另一个表中?Oracle技术网—MIS中的图像应用技术Oracle技术网—MIS中的图像应用技术Oracle技术网—从FORM中调用REPORT时,如何使打印结果直接输出到打印机上Oracle技术网—如何从FORM中调用REPORT程序Oracle技术网—如何改变FORM(FMX模块)运行时的title?Oracle技术网—如何在FORM运行中,使定制菜单中的“窗口(W)”菜单项不显示Oracle技术网—如何在启动FORM程序时直接登录到Oracle数据库上?Oracle技术网—运行FORM时,如何使按钮变灰(即无效)Oracle技术网—运行FORM时,如何使窗口(runtime窗口、画布窗口)自动变成最大化、最小化?Oracle技术网—在Developer/2000中如何读写文本型操作系统文件Oracle技术网—在Oracle中实现报表的定长输出linux vs UnixHow To Install Oracle 8.0.5 onto RedHat Linux 6HOWTO: OAS for Linux on FreeBSDHOWTO: Oracle for Linux on FreeBSDOracle 7.3.4 Enterprise Edition for SCO UNIX 安装步骤Oracle技术网—Oracle .com 套件在TurboLinux上的安装Oracle技术网—ORACLE 7.3 Enterprise在SCO OPEN SERVER 5.02 及 5.04 的安装过程Oracle技术网—ORACLE 7.3.4.2 for SCO Unix 安装说明Oracle技术网—Oracle 8 for solaris 2.6 安装步骤Oracle技术网—Oracle 8(8.0.5)标准版安装指南Oracle技术网—Oracle 8i(8.1.5)企业版安装指南Oracle技术网—ORACLE FOR SUN SOLARIS 安装手册Oracle技术网—ORACLE FOR SUN SOLARIS 维护手册Oracle技术网—ORACLE V.7.3.4.3 FOR AIX 安装说明Oracle技术网—ORACLE8I FOR SUN SOLARIS2.7 安装说明Oracle技术网—RedHat 6.1 Step-by-step Install notes for Oracle 8iOracle技术网—RedHat Linux 6.0 上 Oracle 8(8.0.5)标准版 安装实例Oracle技术网—RedHat Linux 6.0 上 Oracle 8i R2 (8.1.6) 企业版安装实例Oracle技术网—如何集成Linux/Apache/PHP4/FastCGI/Oracle/MySQL环境Oracle技术网—如何在你的Linux机器上安装运行OracleOracle技术网—为Linux配备Oracle 8Oracle技术网—在RedHat 6.0上安装Oracle 8i(全攻略)
文字

构造全中文界面的Developer/2000应用
摘自:中国计算机报社


李刚

  用Oracle的Developer/2000构造的中文界面的应用程序,存在着许多西文的信息。具体表现在:

  1. 在运行时多文档主窗口的缺省标题是:Forms 4.5 (Runform),但在设计时找不到可对该标题进行设置的可视属性。

  2. 当系统成功地完成某一项操作时,将在状态栏上提示英文信息。例如,当查询时不存在满足条件的记录,系统将提示:FRM-40301:Query caused no records to be retrieved .Re-enter。

  3. 当系统执行过程中检测到某项操作错误时,也将在状态栏上提示英文信息。例如,当已到第一条记录时,若用户仍企图继续查看上一条记录,系统将提示:FRM-40110:At first record。

  4. 当用户修改数据后,并未保存数据就企图进行其他操作,如进行查询、记录翻页或退出程序,系统将自动弹出一个英文的Alert窗口,出现以下提示:“DO YOU HAVE WANT TO SAVE THE CHANGES YOU HAVE MADE?”;并要求用户在YES、 NO、 CANCEL三个按钮间进行选择。

  5. 运行时菜单项总有一个英文的WINDOW项,即使将FORM的MENU MODULE属性置为空白也无济于事。

  以上这些情况的出现,破坏了中文应用程序的整体效果,并使用户操作时感到困惑。针对这些问题,下面分别给出解决的方法。


  一、 设置中文的主窗口标题


  在FORM级的TRIGGERS:WHEN-NEW-FORM-INSTANCE中加入以下代码:

  SET_WINDOW_PROPERTY(FORMS_MDI_WINDOW,TITLE,

  'CAAC计算中心业务信息系统( V1.0 )');

  该命令将多文档主窗口的标题设置为“CAAC计算中心业务信息系统( V1.0 )”。运行时该标题将替代缺省的标题“Forms4.5”。

  附带提一下,用SET_WINDOW_PROPERTY命令还可完成对多文档的主窗口和子窗口许多属性的设置。例如,假如多文档子窗口为window0,下面的命令将使文档主窗口和子窗口在运行时自动最大化:

  SET_WINDOW_PROPERTY(FORMS MDI WINDOW, WINDOW STATE, MAXIMIZE);

  SET_WINDOW_PROPERTY('window0', WINDOW STATE, MAXIMIZE);


  二、 汉化西文的提示信息


  Oracle的提示信息分为两类:一类是操作成功的提示信息,如前面提到的第二种情况;一类是操作错误的提示信息,如前面提到的第三种情况。前者将以消息(Message)的形式,自动触发FORM级的TRIGGER:ON-MESSAGE;后者将触发FORM级的TRIGGER:ON-ERROR。因此,我们可以在这两个触发器中,捕捉并汉化英文的提示信息。

  汉化英文信息的基本思想是建立一个汉化信息表,在表中存储系统的信息编号和对应的中文汉化信息。当利用触发器捕捉到系统信息时,查询该表,取出中文信息,显示在状态栏上。下面是汉化以消息的形式出现的系统信息的步骤:

  1. 在SQL-PLUS中创建汉化信息表:

  Create table chi_errmsg(

  msgno NOT NULL VARCHAR2(6),

  chinesemsg VARCHAR2(60),

  PRIMARY KEY ( msgno)

  );

  表chi_errmsg中,msgno字段用以记录系统的信息编号,我们约定该字段的记录方法为:前缀(1位)+信息编号(5位)。其中前缀‘M’表示该信息为系统消息;‘E’表示该信息为系统错误消息。chinesemsg是编号相对应的中文提示信息。

  2. 在FORM级的触发器ON-MESSAGE中写入如下代码:

  DECLARE

  Mesgno varchar(6);

  Errormesg varchar2(60);

  Msg_frm varchar2(200);

  BEGIN

  

  Msg_frm:=MESSAGE_TYPE||'-'||TO_CHAR(MESSAGE_CODE)||':'||MESSAGE_TEXT;

  

  Mesgno := 'M'||TO_CHAR(MESSAGE_CODE);

  

  SELECT chinesemsg INTO

  Errormesg

  FROM chi_errmsg

  WHERE msgno = Mesgno;

  

  MESSAGE(MESSAGE_TYPE||'-'||TO_CHAR(MESSAGE_CODE)||':'||Errormesg,NO_ACKNOWLEDGE);

  EXCEPTION

  WHEN others THEN

  

  MESSAGE(Err_frm,NO_ACKNOWLEDGE);

  END;

  在上面的代码中,MESSAGE_TYPE、MESSAGE_CODE、MESSAGE_TEXT三个系统变量记载了消息的类型、编号及内容。以本文开始提到的第二种情况为例,当出现“FRM-40301:Query caused no records to be retrieved .Re-enter”消息时,

  MESSAGE_TYPE="FRM";

  MESSAGE_CODE="40301";

  MESSAGE_TEXT="Query caused no records to be retrieved .Re-enter"。

  由于每一个消息都有一个唯一的编号,因此可依据该编号来查找对应的中文信息。

  3.充实汉化信息表的内容

  通过上面两步,我们已完成了对系统消息的捕捉和汉化工作。接下来的工作就是在应用开发的过程中,针对应用中可能出现的西文信息,捕捉一个,汉化一个。例如,我们需要对“FRM-40301:Query caused no records to be retrieved .Re-enter”汉化,只需要在chi_errmsg表中加入一条记录即可:

  insert into chi_errmsg values('M40301','本次查询没有取出符合条件的记录!请再试');

  对系统错误信息的汉化与消息汉化的思想相同,下面给出在ON-ERROR触发器中的代码供读者参考:

  DECLARE

  Mesgno varchar(6);

  Errormesg varchar2(60);

  Err_frm varchar2(200);

  BEGIN

  Errfrm :=ERROR_TYPE||'-'||TO_CHAR(ERROR_CODE)||':'||ERROR TEXT;

  Mesgno := 'E'||TO_CHAR(ERROR_CODE);

  SELECT chinesemsg INTO

  Errormesg

  FROM chi_errmsg

  WHERE msgno = Mesgno;

  MESSAGE(ERROR_TYPE||'-'||TO_CHAR(ERROR_CODE)||':'||Errormesg, NO ACKNOWLEDGE);

  EXCEPTION

  WHEN others THEN

  MESSAGE(Err_frm,NO_ACKNOWLEDGE);

  END;

  针对"FRM-40110:At first record"错误,在chi_errmsg表中插入:

  insert into chi_errmsg values('E40100','已到第一条记录!');

  最后提醒读者,一个系统提示信息类型究竟是“ERROR”还是“MESSAGE”,可查阅Developer/2000的参考手册。


  三 、替换西文Alert窗口


  设计的基本思想是建立一个中文的Alert,并在可能出现西文Alert的地方加上代码触发中文的Alert警告,提醒用户进行存储。

  例如,针对本文开始提到的第四种情况,为使系统退出时不再出现西文Alert窗口,可在FORM级的TRIGGER:KEY-EXIT中加入如下代码:

  DECLARE

  return_value number;

  alert_id Alert;

  BEGIN

  IF :SYSTEM.FORM_STATUS= 'CHANGED' THEN

  alert_id := Find_Alert('stop_alert');

  SET_ALERT_PROPERTY(alert_id,alert_message_text,'数据已经改变!确认是否存储?');

  return_value := SHOW_ALERT( alert_id );

  IF return_value = ALERT_BUTTON1 THEN

  COMMIT_FORM;

  ELSE

  CLEAR_FORM(NO_COMMIT);

  END IF;

  ELSE

  CLEAR_FORM(NO_COMMIT);

  END IF;

  EXIT_FORM;

  END;

  这段代码的基本思想是当记录值发生改变时,弹出中文的Alert,提醒用户存储。'stop_alert'是我们自制的中文Alert,它有两个按钮:确认、取消。当返回第一个按钮(即确认按钮)时,系统提交对数据的修改,否则取消修改。这样,当执行EXIT_FORM命令时,将不会出现原有的西文Alert。


  四 、消除菜单中的Window项


  用户程序有两种情况,一种是不需要菜单;一种是具有中文的菜单。这两种情况下消除Window项的方法为:

  (一)用户程序不需要菜单

  1. FORM中的MENU MODULE属性:为空。

  2. Window中的MODAL属性:TRUE。

  (二)用户程序有中文菜单

  1. 在用户菜单中建立一个Item,命名为WINDOW。

  2. 设置该Item属性如下:

  Menu Item Type:Magic

  Command Type:Null

  Magic Item:Window

  Lable:为空



上一篇:下一篇: