本文出自: 作者: (2001-08-13 07:00:00) 
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
  n  number;
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_id  Editor; 
  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_id  LOV; 
  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)=1  floor(-1.3)=-2
---返回大于或等于数的最小整数
   CEIL(VALUE)    cell (1.3)=2  cell (-1.3)=-1
---取字符串长度
   substr(string,start,number)  number为string长度,start为string起点
        
---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|DESC  ASC''升'',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 当''数字的,数据转换,截字符串或强制性的错误''时
       WHEN VALUE_ERROR THEN  
**************************************************************************
**************************************************************************
--常用TEXT_IO
Delcare
  out_file  text_io.file_type;
Begin
  out_file:=text_io.fopen(''prn'',''w'');
  text_io.new_line(out_file,'' '');
  text_io.put_line(out_file,'' '')
  text_io.fclose(out_file);
End;
---文本输入输出
   TEXT_IO
   TEXT_IO PACKAGE
   TEXT_IO FCLOSE
   TEXT_IO.FILE_TYPE
   TEXT_IO.FOPEN
   TEXT_IO.IS_OPEN
   TEXT_IO.GET_LINE
   TEXT_IO.NEW_LINE
   TEXT_IO.PUT
   TEXT_IO.PUTF
   TEXT_IO.PUT_LINE
  USING TEXT_IO CONSTRUCTS
----------------------------
Declare
     Out_file     Text_io.file_type;
     L            Varchar2(100);
     L1           Varchar2(100);
     L2           Varchar2(100);
Begin
    Out_file :=text_io.fopen(''c:lllogin.txt'',''r'');
    If text_io.is_open(Out_file) then
	text_io.get_line(Out_file,L);
	text_io.get_line(Out_file,L1);
	text_io.get_line(Out_file,L2);
    Else
        Null;
    End if;
End;   
---清除全局变量
   erase(''global.var_name'');
---隐藏''WINDOW'',''VIEW'',''MENU''
   HIDE_WINDOW|VIEW|MENU(WINDOW|VIEW|MENU_name);
--- 增加参数add_parameter
Declare
  pl_id ParamList; 
BEGIN 
  pl_id:=Get_Parameter_List(''tempdata''); 
  IF NOT Id_Null(pl_id) THEN 
     Destroy_Parameter_List(pl_id); 
  END IF; 
  pl_id:=Create_Parameter_List(''tempdata''); 
  Add_Parameter(pl_id,''EMP_QUERY'',DATA_PARAMETER,''EMP_RECS''); 
  Run_Product(REPORTS,''empreport'',SYNCHRONOUS,RUNTIME, 
              FILESYSTEM,pl_id,NULL); 
END; 
---
DECLARE
  lArgs OLE2.LIST_TYPE;
BEGIN
  word.hApp:=OLE2.CREATE_OBJ(''Word.Basic'');
  lArgs:=OLE2.CREATE_ARGLIST;
  OLE2.ADD_ARG(lArgs,:ole.word_doc);
  OLE2.INVOKE(Word.hApp,''fileopen'',lArgs);
  OLE2.DESTROY_ARGLIST(lArgs);
END;
***********************删除重复记录**************
  Delete from emp e
  where e.rowid >
   (select min(f.rowid) from emp f
    4 where f.empno=e.empno);