ORACLE應(yīng)用經(jīng)驗(yàn)(1)
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)
********************************************************************
****************************常用設(shè)置********************************
---on-log 觸發(fā)器編寫(xiě)示范
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,
'登錄失敗,請(qǐng)返回重試');
n:=show_alert('a_1');
raise form_trigger_failure; --中斷 FORM
End if;
End;
---對(duì)基表執(zhí)行查詢(只對(duì)基表)
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
***************************************************
---同步發(fā)生顯示
synchronize;
---實(shí)施'TRIGGER'觸發(fā)
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設(shè)置
--運(yùn)行時(shí)最大化,最小化
Set_Window_Property(FORMS_MDI_WINDOW, WINDOW_STATE, MAXIMIZE|MINIMIZE);
--WINDOW標(biāo)題
Set_Window_Property(FORMS_MDI_WINDOW, title,'TEXT');
--退出是否為真
Set_Window_Property(FORMS_MDI_WINDOW, REMOVE_ON_EXIT,PROPERTY_FALSE|TRUE);
---設(shè)置系統(tǒng)提示信息等級(jí)
:System.Message_Level:= '5|10|15|20';
---設(shè)置ITEM屬性
--設(shè)置ITEM屬性ENABLED
Set_Item_Property('Block_name.Item_name',ENABLED,PROPERTY_TRUE|FALSE);
--設(shè)置ITEM屬性NAVIGABLE
Set_Item_Property('Block_name.Item_name',NAVIGABLE,PROPERTY_TRUE|FALSE);
--設(shè)置ITEM屬性VISUAL_ATTRIBUTE
Set_Item_Property('Block_name.Item_name',visual_attribute,'vname');
--'vname'由導(dǎo)航器中(VISUAL_ATTRIBUTES)定義
--設(shè)置ITEM屬性DISPLAYED
Set_Item_Property('Block_name.Item_name',displayed,TRUE|FALSE);
--設(shè)置ITEM屬性POSITION
Set_Item_Property('Block_name.Item_name',position,x,y);
--設(shè)置ITEM_SIZE
Set_Item_Property('Block_name.Item_name',item_size,x,y);
--設(shè)置ITEM屬性LABLE
Set_Item_Property('Block_name.Item_name',LABEL,'MESSAGE')
---設(shè)置LIST ITEM示范
Declare
&nbs正在看的ORACLE教程是:ORACLE應(yīng)用經(jīng)驗(yàn)(1)。p; 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'項(xiàng)
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'項(xiàng)的組成
1.獲得'LIST ITEM'的總和
GET_LIST_ELEMENT_COUNT(list_id);
GET_LIST_ELEMENT_COUNT(list_name);
2.獲得'LIST ITEM'的標(biāo)簽
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);
---設(shè)置'時(shí)間'
DECLARE
timer_id Timer;
one_minute NUMBER(5) := 60000;
BEGIN
timer_id := CREATE_TIMER('emp_timer', one_minute, REPEAT|NO_REPEAT);
END;
---產(chǎn)生一個(gè)'EDITER'框
DECLARE
ed_id Editor;
status BOOLEAN;
BEGIN
ed_id:=Find_Editor('edit_name'); ---由'edit_name'導(dǎo)航器定義
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;
----產(chǎn)生一個(gè)'LOV'框
DECLARE
lv_id LOV;
status BOOLEAN;
BEGIN
lv_id := Find_LOV('lov_name'); ---'lov_name' 由導(dǎo)航器定義
-- IF Id_Null(lv_id) THEN
-- lv_id := Find_LOV('lov_name1'); ---'lov_name1' 由導(dǎo)航器定義
-- END IF;
status := Show_LOV(lv_id,10,20);
END;
---定義一個(gè)'EXCEPTION'例外
Declare
err_1 exception;
Begin
If ... then
Raise err-1;
End if;
Exception
When err_1 then
....
END;
---設(shè)置應(yīng)用特性(光標(biāo)類型)
SET_APPLICATION_PROPERTY(CURSOR_STYLE,
'CROSSHAIR'|'BUSY'|'HELP'|'DEFAULT'|'INSERTION');
***********************************************************************
**********************************函數(shù)*********************************
---把字符串的字符變成全大寫(xiě)(UPPER)全小寫(xiě)(LOWER)第一個(gè)字母大寫(xiě)(INITCAP)
UPPER|LOWER|INITCAP(STRING)
---在文件的左('LPAD')右('RPAD')粘貼字符
LPAD|RPAD(STRING,LENGTH,'SET') "LENGTH"為總字符長(zhǎng)"SET"為粘貼字符
---在文件的左('LTRIM')右('RTRIM')刪除字符
LTRIM|RTRIM(SRTING,'SET') "SET"為待刪除字符
---找出'字符集'在字符串中的位置
INSTR('STRING','SET',N,M) 從'STRING'中找出'SET'從'N'位起第'M'個(gè)
---數(shù)的絕對(duì)值
ABS(VALUE)
---'MOD'模
MOD(VALUE,除數(shù)) 返回'除數(shù)'除'VALUE
上一頁(yè) [1] [2] [3] [4] [5] 下一頁(yè)
正在看的ORACLE教程是:ORACLE應(yīng)用經(jīng)驗(yàn)(1)。'的余數(shù)常用判斷'VALUE'是否為整數(shù)---把'VALUE'從'N'位四舍五入'ROUND' 或從'N'位截?cái)?TRUNC'
ROUND|TRUNC(VALUE,N)
---返回'VALUE'的符號(hào)
SIGN(VALUE)
---列表的最大值
GREATEST(N1,N1...);
列表的最小值
LEAST(N1,N1...);
---返回小于或等于數(shù)的最大整數(shù)
FLOOR(VALUE) floor(1.3)=1 floor(-1.3)=-2
---返回大于或等于數(shù)的最小整數(shù)
CEIL(VALUE) cell (1.3)=2 cell (-1.3)=-1
---取字符串長(zhǎng)度
substr(string,start,number) number為string長(zhǎng)度,start為string起點(diǎn)
---DECODE函數(shù),多重(if,then,else)
decode(value,if1,then1,if2,then2,.....,else)
---判斷'VALUE'是否為空(空值替換)
NVL(UALUE,'WKFHZ') 'WKFHZ'是為空返回值,不為空則為原值
---字段長(zhǎng)度
length(:block_name.item_id)
---返回字符串的第一(最左)個(gè)字符的ascII值
ascII(string)
---多行'VALUE'的 (作用于多'行')
AVG(VALUE)平均值
COUNT(VALUE)行數(shù)
MAX(VALUE)最大值
MIN(VALUE)最小值
SUM(VALUE)和
---字符轉(zhuǎn)換
TRANSLATE(STRING,'待轉(zhuǎn)字符','轉(zhuǎn)換字符');
如 TEANSLATE('AAABBB','AB','BA') 返回'BBBAAA'
---比較單行中多個(gè)列的值獲得最大('GREATEST'最小('LEAST')
GREATEST|LEAST(列名,列名,...)
---按表達(dá)式或位置排序
ORDER BY '表達(dá)式'OR'位置' ASC|DESC ASC'升',DESC'降' 默認(rèn)'ASC'
***********************************************************************
***********************************************************************
---游標(biāo)的屬性
(1) %ISOPEN 打開(kāi)屬性 布爾型 打開(kāi)為T(mén)RUE
判斷'光標(biāo)'是否打開(kāi)如未打開(kāi)則打開(kāi)'光標(biāo)'
IF NOT(CORSOR_NAME%ISOPEN) THEN
OPEN CORSOR_NAME;
END IF;
FETCH CORSOR_NAME INTO ...
(2) %NOTFOUND 布爾型 最近一次'FETCH'返回?zé)o結(jié)果 則為T(mén)RUE
OPEN CORSOR_NAME;
LOOP
FETCH CORSOR_NAME INTO ...
EXIT WHEN CORSOR_NAEM%NOTFOUND;
END LOOP;
(3) %FOUND 布爾型 最近一次'FETCH'返回?zé)o結(jié)果 則為FALSE
OPEN CORSOR_NAME;
WHILE CORSOR_NAME%FOUND LOOP
......
FETCH CORSOR_NAME INTO ...
END LOOP;
CLOSE CORSOR_NAME;
(4) %ROWCOUNT NUMVER型 為游標(biāo)取出的行數(shù)
OPEN CORSOR_NAME;
LOOP
FETCH CORSOR_NAME INTO ...
EXIT WHEN CORSOR_NAME%ROWCOUNT>5;
......
END LOOP;
CLOSE CORSOR_NAME;
---循環(huán)語(yǔ)句
(1)基本循環(huán)
LOOP
.....
EXIT WHILE; 如(EXIT WHEN X>100)
END LOOP;
(2)WHILE循環(huán)
WHILE 如( WHEN X>100) LOOP
.....
 
上一頁(yè) [1] [2] [3] [4] [5] 下一頁(yè)
正在看的ORACLE教程是:ORACLE應(yīng)用經(jīng)驗(yàn)(1)。; END LOOP;(3)數(shù)值型FOR循環(huán) 'X'為計(jì)數(shù)器
FOR X IN (第減值) Y..Z LOOP
.....
END LOOP;
(4)游標(biāo)FOR循環(huán)
---Exception(例外)在最近的'BEGIN'和'END'之間
Exception
語(yǔ)法1 當(dāng)'沒(méi)有數(shù)據(jù)找到'時(shí)
when no_data_found then
語(yǔ)法2 當(dāng)'發(fā)生任何錯(cuò)誤'時(shí)
when others then
語(yǔ)法3 當(dāng)'發(fā)現(xiàn)多行'時(shí)
WHEN TOO_MANY_ROWS THEN
語(yǔ)法4 當(dāng)'字符向數(shù)字轉(zhuǎn)換失敗'時(shí)
WHEN INVALID_NUMBER THEN
語(yǔ)法5 當(dāng)'被零除'時(shí)
WHEN ZERO_DIVIDE THEN
語(yǔ)法6 當(dāng)'向唯一索引中插入重復(fù)數(shù)據(jù)'時(shí)
WHEN DUP_VAL_ON_INDEX THEN
語(yǔ)法7 當(dāng)'非法游標(biāo)操作'時(shí)
WHEN INVALID_CURSOR THEN
語(yǔ)法8 當(dāng)'數(shù)字的,數(shù)據(jù)轉(zhuǎn)換,截字符串或強(qiáng)制性的錯(cuò)誤'時(shí)
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);
--- 增加參數(shù)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;
***********************刪除重復(fù)記錄**************
Delete from emp e
where e.rowid >
 
上一頁(yè) [1] [2] [3] [4] [5] 下一頁(yè)
正在看的ORACLE教程是:ORACLE應(yīng)用經(jīng)驗(yàn)(1)。; (select min(f.rowid) from emp f4 where f.empno=e.empno);
相關(guān)文章
Oracle數(shù)據(jù)庫(kù)的備份與恢復(fù)
Oracle數(shù)據(jù)庫(kù)的備份與恢復(fù)...2007-03-03Oracle 10G:PL/SQL正規(guī)表達(dá)式(正則表達(dá)式)手冊(cè)
Oracle Database 10g 的一個(gè)新特性大大提高了您搜索和處理字符數(shù)據(jù)的能力。這個(gè)特性就是正規(guī)表達(dá)式,是一種用來(lái)描述文本模式的表示方法。很久以來(lái)它已在許多編程語(yǔ)言和大量 UNIX 實(shí)用工具中出現(xiàn)過(guò)了。2009-06-06Oracle全角數(shù)字轉(zhuǎn)換半角數(shù)字
今天小編就為大家分享一篇關(guān)于Oracle全角數(shù)字轉(zhuǎn)換半角數(shù)字,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-01-01詳解Oracle中的隱含參數(shù)_disable_logging
之前看到過(guò)一篇文章是介紹Oracle的一個(gè)內(nèi)部隱含參數(shù)_disable_logging,最近又看到有朋友論述這個(gè)參數(shù),所以下面這篇文章就來(lái)給大家介紹下關(guān)于Oracle中隱含參數(shù)_disable_logging的相關(guān)資料,需要的朋友可以參考下。2017-02-02解決PL/SQL修改Oracle存儲(chǔ)過(guò)程編譯就卡死的問(wèn)題
這篇文章主要介紹了PL/SQL修改Oracle存儲(chǔ)過(guò)程編譯就卡死,本文給大家分享問(wèn)題原因及解決方法,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01Oracle round()函數(shù)與trunc()函數(shù)區(qū)別介紹
本文將詳細(xì)介紹Oracle round()函數(shù)與trunc()函數(shù)區(qū)別,需要了解的朋友可以參考下2012-11-11oracle數(shù)據(jù)庫(kù)表實(shí)現(xiàn)自增主鍵的方法實(shí)例
Oracle數(shù)據(jù)庫(kù)中沒(méi)有自增字段,我們可以通過(guò)創(chuàng)建序列和觸發(fā)器的方式,間接地實(shí)現(xiàn)自增的效果,下面這篇文章主要給大家介紹了關(guān)于oracle數(shù)據(jù)庫(kù)表實(shí)現(xiàn)自增主鍵的相關(guān)資料,需要的朋友可以參考下2022-06-06