`
isiqi
  • 浏览: 15999638 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

ORACLE应用经验(1)[转载]

阅读更多
ORACLE应用经验(1)
JAN-1(January) FEB-2(February) MAR-3(March)
APR-4(April) MAY-5(May) JUN-6(June)
JUL-7(July) AUG-8(August) SEP-9(September)
OCT-10(October)NOV-11(November)DEC-12(December)
********************************************************************
****************************常用设置********************************
---on-log 触发器编写示范
Declare
flag varchar2(80):=null;
cou number:=1;
n number;
Begin
Loop
 logon(USERNAME,PASSWORD||'@'||CONNECT,PROPERTY_FALSE....);
 flag:=Get_Application_Property(DATASOURCE);
 Exit when cou>8 or flag='ORACLE';
 cou:=cou+1;
End Loop;
If flag<>'ORACLE' then
 set_alert_property('a_1',alert_message_text,
 '登录失败,请返回重试');
n:=show_alert('a_1');
 raise form_trigger_failure; --中断 FORM
End if;
End;
---对基表执行查询(只对基表)
 Set_Block_Property('Block_Name',Default_Where,'where ......');
 Go_Block('Block_Name');
 Execute_Query;
 ***************************************************
变量:
 局部变量;
 全局变量--------------1.:block.item
  2.:parameter.v_name
  3.:global.V_name
 
***************************************************
---同步发生显示
 synchronize; 
---实施'TRIGGER'触发
 EXECUTE_TRIGGER(TRIGGER_NAME);
---清除模块
 clear_block(NO_VALIDATE);'NO_VALIDATE'不生效
--建立警告栏并由警告栏选择
Declare
 n number;
Begin
 Set_Alert_Property('Alert_Name',Alert_Message_Text,'message');
 n:=Show_Alert('Alert_Name');
 If n=Alert_Button1 then
 ...; 
ElsIf n=Alert_Button2 then 
...;
 End if;
End;
---WINDOW设置
--运行时最大化,最小化
Set_Window_Property(FORMS_MDI_WINDOW, WINDOW_STATE, MAXIMIZE|MINIMIZE);
--WINDOW标题
Set_Window_Property(FORMS_MDI_WINDOW, title,'TEXT');
--退出是否为真
Set_Window_Property(FORMS_MDI_WINDOW, REMOVE_ON_EXIT,PROPERTY_FALSE|TRUE);
---设置系统提示信息等级
:System.Message_Level:= '5|10|15|20'; 
---设置ITEM属性
--设置ITEM属性ENABLED
Set_Item_Property('Block_name.Item_name',ENABLED,PROPERTY_TRUE|FALSE);
--设置ITEM属性NAVIGABLE
Set_Item_Property('Block_name.Item_name',NAVIGABLE,PROPERTY_TRUE|FALSE);
--设置ITEM属性VISUAL_ATTRIBUTE
Set_Item_Property('Block_name.Item_name',visual_attribute,'vname'); 
--'vname'由导航器中(VISUAL_ATTRIBUTES)定义
--设置ITEM属性DISPLAYED
Set_Item_Property('Block_name.Item_name',displayed,TRUE|FALSE);
--设置ITEM属性POSITION
Set_Item_Property('Block_name.Item_name',position,x,y);
--设置ITEM_SIZE
Set_Item_Property('Block_name.Item_name',item_size,x,y);
--设置ITEM属性LABLE
Set_Item_Property('Block_name.Item_name',LABEL,'MESSAGE')
---设置LIST ITEM示范
Declare
nnumber;
Begin
 clear_list('b1.fkfs');
 m:=populate_group('fkfs');
 populate_list('b1.fkfs','fkfs');
/*
 其中FKFS  record group ;
*/
End;
---增加'LIST ITEM'
 Add_List_Element(list_name, list_index, list_label, list_value);
 Add_List_Element(list_id, list_index, list_label, list_value);
---删除'LIST ITEM'
 Delete_List_Element(list_name, list_index);
 Delete_List_Element(list_id, list_index);
 :
 BEGIN 
Delete_List_Element('years',1); 
Add_List_Element('years', 1, '1994', '1994'); 
END; 
---获得'LIST ITEM'项的组成
 1.获得'LIST ITEM'的总和 
GET_LIST_ELEMENT_COUNT(list_id);
 GET_LIST_ELEMENT_COUNT(list_name); 
2.获得'LIST ITEM'的标签
 GET_LIST_ELEMENT_LABEL(list_id, list_name, list_index); 
GET_LIST_ELEMENT_LABEL(list_name, list_index);
 
3.获得'LIST ITEM'的值
 GET_LIST_ELEMENT_VALUE(list_id, list_index); 
GET_LIST_ELEMENT_VALUE(list_name, list_index);
---设置'时间'
DECLARE 
timer_id Timer; 
one_minute NUMBER(5) := 60000; 
BEGIN 
timer_id := CREATE_TIMER('emp_timer', one_minute, REPEAT|NO_REPEAT); 
END;
---产生一个'EDITER'
DECLARE 
ed_idEditor; 
status BOOLEAN; 
BEGIN 
ed_id:=Find_Editor('edit_name'); ---'edit_name'导航器定义
IF NOT Id_Null(ed_id) THEN 
Show_Editor(ed_id, NULL, :block_name.item_name, status);
ELSE 
Message('Editor "Happy_Edit_Window" not found'); 
RAISE Form_Trigger_Failure; 
END IF; 
END; 
----产生一个'LOV'
DECLARE 
lv_idLOV; 
status BOOLEAN; 
BEGIN 
lv_id := Find_LOV('lov_name'); ---'lov_name' 由导航器定义
--IF Id_Null(lv_id) THEN 
-- lv_id := Find_LOV('lov_name1'); ---'lov_name1' 由导航器定义
--END IF; 
status := Show_LOV(lv_id,10,20); 
END; 
---定义一个'EXCEPTION'例外
Declare
err_1 exception;
Begin
If ...then
 Raise err-1;
End if;
Exception
 When err_1 then
 ....
END;
---设置应用特性(光标类型)
 SET_APPLICATION_PROPERTY(CURSOR_STYLE,
 'CROSSHAIR'|'BUSY'|'HELP'|'DEFAULT'|'INSERTION');
 
*********************************************************************** 
**********************************函数*********************************
---把字符串的字符变成全大写(UPPER)全小写(LOWER)第一个字母大写(INITCAP)
 UPPER|LOWER|INITCAP(STRING)
---在文件的左('LPAD')('RPAD')粘贴字符
 LPAD|RPAD(STRING,LENGTH,'SET')"LENGTH"为总字符长"SET"为粘贴字符
---在文件的左('LTRIM')('RTRIM')删除字符
 LTRIM|RTRIM(SRTING,'SET') "SET"为待删除字符
---找出'字符集'在字符串中的位置
INSTR('STRING','SET',N,M)'STRING'中找出'SET''N'位起第'M'
---数的绝对值
 ABS(VALUE)
---'MOD'
 MOD(VALUE,除数) 返回'除数''VALUE'的余数常用判断'VALUE'是否为整数 
---'VALUE''N'位四舍五入'ROUND'或从'N'位截断'TRUNC'
 ROUND|TRUNC(VALUE,N)
---返回'VALUE'的符号
 SIGN(VALUE)
 
---列表的最大值
 GREATEST(N1,N1...);
 列表的最小值
 LEAST(N1,N1...);
---返回小于或等于数的最大整数
 FLOOR(VALUE) floor(1.3)=1floor(-1.3)=-2
---返回大于或等于数的最小整数
 CEIL(VALUE) cell (1.3)=2cell (-1.3)=-1
---取字符串长度
 substr(string,start,number)numberstring长度,startstring起点
 
---DECODE函数,多重(if,then,else)
 decode(value,if1,then1,if2,then2,.....,else)
---判断'VALUE'是否为空(空值替换)
 NVL(UALUE,'WKFHZ')'WKFHZ'是为空返回值,不为空则为原值
---字段长度
 length(:block_name.item_id)
---返回字符串的第一(最左)个字符的ascII
 ascII(string)
---多行'VALUE' (作用于多'')
 AVG(VALUE)平均值
 COUNT(VALUE)行数
 MAX(VALUE)最大值
 MIN(VALUE)最小值
 SUM(VALUE)
---字符转换
 TRANSLATE(STRING,'待转字符','转换字符');
 TEANSLATE('AAABBB','AB','BA')返回'BBBAAA'
 
---比较单行中多个列的值获得最大('GREATEST'最小('LEAST')
 GREATEST|LEAST(列名,列名,...)
---按表达式或位置排序
ORDER BY '表达式'OR'位置' ASC|DESCASC'',DESC'' 默认'ASC' 
***********************************************************************
***********************************************************************
---游标的属性
 (1) %ISOPEN打开属性布尔型打开为TRUE 
判断'光标'是否打开如未打开则打开'光标'
 IF NOT(CORSOR_NAME%ISOPEN) THEN
 OPEN CORSOR_NAME;
 END IF;
 FETCH CORSOR_NAME INTO ...
 (2) %NOTFOUND 布尔型最近一次'FETCH'返回无结果则为TRUE
 OPEN CORSOR_NAME;
 LOOP
 FETCH CORSOR_NAME INTO ... 
EXIT WHEN CORSOR_NAEM%NOTFOUND;
 END LOOP;
 (3) %FOUND 布尔型最近一次'FETCH'返回无结果则为FALSE
 OPEN CORSOR_NAME;
 
WHILE CORSOR_NAME%FOUND LOOP
 ......
 FETCH CORSOR_NAME INTO ... 
END LOOP;
 CLOSE CORSOR_NAME; 
(4) %ROWCOUNT NUMVER为游标取出的行数
 OPEN CORSOR_NAME;
 LOOP
 FETCH CORSOR_NAME INTO ... 
EXIT WHEN CORSOR_NAME%ROWCOUNT>5; 
...... 
END LOOP; 
CLOSE CORSOR_NAME; 
---循环语句
 (1)基本循环
 LOOP 
.....
 EXIT WHILE; (EXIT WHEN X>100)
 END LOOP;
 (2)WHILE循环
WHILE ( WHEN X>100) LOOP
 .....
 END LOOP;
 (3)数值型FOR循环'X'为计数器
FOR X IN (第减值) Y..Z LOOP
 .....
 END LOOP;
 (4)游标FOR循环
 
---Exception(例外)在最近的'BEGIN''END'之间
 Exception
 语法1 '没有数据找到'
 when no_data_found then 
语法2 '发生任何错误'
 when others then 
语法3 '发现多行'
 WHEN TOO_MANY_ROWS THEN
语法4 '字符向数字转换失败'
 WHEN INVALID_NUMBER THEN 
语法5 '被零除'
 WHEN ZERO_DIVIDE THEN 
语法6 '向唯一索引中插入重复数据'
 WHEN DUP_VAL_ON_INDEX THEN
 语法7 '非法游标操作'
 WHEN INVALID_CURSOR THEN
 语法8 '数字的<

  


  
分享到:
评论

相关推荐

    转载 在 Oracle 数据库上构建 .NET 应用程序

    我把 http://www.oracle.com/technology/global/cn/pub/articles/cook_dotnet.html 制成了 pdf格式,以方便大家收藏阅读

    Oracle Concepts 中文英文对照版 (10g R2)

    Chapter 1, Introduction to the Oracle Database 第 1 章,Oracle 数据库简介 Part II Oracle Database Architecture 第二部分 Oracle 数据库体系结构 Chapter 2, Data Blocks, Extents, and Segments...

    Oracle 数据库客户端

    4、下载并安装PL.SQL.Developer配置应用 貌似把环境变量Path添加了instantclient就可以了,不需要具体的设置。 配置tools-&gt;preferences-&gt;connection Oracle Home  D:/instantclient_11_2 OCI library  D:/instant...

    TNS-12541: TNS: 无监听程序 TNS-12560

    前天应用不能访问数据库了 (后台应用能访问数据库),故障发生。 马上登录到服务器里查看监听状态,发现有TNS-12541 ,TNS-12560等错误 Luocs补充:我跟朋友要了错误代码,但他没有保存,就直接贴图。 从计算器的...

    Java&WebSocket;编程 开发、部署和保护动态Web应用

    websocket最好的学习资料,由oracle出版,转载自https://download.csdn.net/download/zhangtianshun/10200593

    jdbc连接数据库的方式2

     在调用存储过程时,我们可以使用SQL92或Oracle PL/SQL,由于使用Oracle PL/SQL并没有什么实际的好处,而且会给以后维护你的应用程序的开发人员带来麻烦,因此,我建议在调用存储过程时使用SQL92。  9、使用Object...

    通用串行总线USB及其应用

    1引言如今,随着计算机在各个领域中的应用日益普及和深入,其外设也越来越多,如打印机、扫描仪、游戏杆、MIC... 此内容为AET网站原创,未经授权禁止转载。

    chinamobile项目

    (1)在oracle数据库中运行数据库脚本文件cnc.sql. (2)用eclipse(或其它开发工具)直接导入工程. (3)将spring配置文件applicationContext.xml中数据库连接地址改为您自已的地址。 (4)部署到tomcat服务器中即可运行(jdk...

    NC65安装过程及安装问题启动问题总结

    原创总结,非官网或其他转载 总结了3台虚拟机多次反复安装测试的心得:包括oracle详细安装步骤,NC65详细安装步骤及关键点备注,常见问题及排除方法 。

    asp.net知识库

    从NUnit中理解.NET自定义属性的应用(转载) 如何在.NET中实现脚本引擎 (CodeDom篇) .NET的插件机制的简单实现 我对J2EE和.NET的一点理解 难分难舍的DSO(一) InternalsVisibleToAttribute,友元程序集访问属性 ...

    采用struts+spring+hibernate架构电信业务系统

    &lt;br&gt;使用方法: (1)在oracle数据库中运行数据库脚本文件cnc.sql. (2)用eclipse(或其它开发工具)直接导入工程. (3)将spring配置文件applicationContext.xml中数据库连接地址改为您自已的地址。...

    中国移动业务管理系统(struts+spring+hibernate)源码

    使用方法: (1)在oracle数据库中运行数据库脚本文件cnc.sql. (2)用eclipse(或其它开发工具)直接导入工程. (3)将spring配置文件applicationContext.xml中数据库连接地址改为您自已的地址。 (4)部署到...

    保险数据分析行业研究及十四五规划分析报告(2020-2026).doc

    拉美(墨西哥和巴西等) 中东及非洲地区 本文正文共9章,各章节主要内容如下: 第1章:报告统计范围、产品细分、下游应用领域,以及行业发展总体概况、有利和不利 因素、进入壁垒等; 第2章:全球市场总体规模、中国...

    ibm_mtk_V2_win.rar

    这个新的迁移实用程序提供了向导和易于使用的五步界面,这些有助于您快速地将现有的 Sybase、 Microsoft SQL Server和Oracle数据库对象转换到 DB2 通用数据库。使用 MTK,可以将数据类型、表、列、视图、索引、存储...

    BlackBerry开发平台配置及入门介绍(傻瓜教程)

     1、 应用描述  A公司是一家外资独资公司,在北京、海南、广东设立了多家分公司,由于需要随时随地的收发邮件和传送会议文件,以便掌握公司最新的决策及动态,公司决定使用具有较高安全性和实时性的BlackBerry业务...

    方便好用的远程数据库对象V1.3

    欢迎转载,但请保留出处,谢谢 ******************************* 很久没有发布东东了,今天看到盒子上有朋友发布了个三层的东东, 下来大概看了看,貌似使用起来不太方便,曾经用过ASTA和RmoObject,都不是那么让...

    二十三种设计模式【PDF版】

    1.设计模式更抽象,J2EE 是具体的产品代码,我们可以接触到,而设计模式在对每个应用时才会产生具体代码。 2.设计模式是比 J2EE 等框架软件更小的体系结构,J2EE 中许多具体程序都是应用设计模式来完成的,当你深入...

    java8集合源码分析-Notes:笔记

    java8 集合源码分析 Java学习指南 目录 Java 并发 JVM JAVA8 设计模式 编程规范 开发框架 前端框架 后端框架 服务器软件 ...Web应用服务器 ...Oracle ...若你喜欢本站内容,欢迎转载,但请注明出处,且勿用于

    springmybatis

    1.Configuration.xml 是 mybatis 用来建立 sessionFactory 用的,里面主要包含了数据库连接相关东西,还有 java 类所对应的别名,比如 &lt;typeAlias alias="User" type="com.yihaomen.mybatis.model.User"/&gt; 这个别名...

Global site tag (gtag.js) - Google Analytics