在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
正在看的ORACLE教程是: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 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); ---设置时间 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 ---取字符串长度 ---DECODE函数,多重(if,then,else) 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:\ll\login.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); |
请发表评论