標籤:
- 擴充資料庫的功能
- 為 PL/SQL 提供對 SQL 功能的訪問
- 使用者 SYS 擁有所有程式包
- 是公有同義字
- 可以由任何使用者訪問
一些內建程式包
程式包名稱 |
說明 |
STANDARD和DBMS_STANDARD |
定義和擴充PL/SQL語言環境 |
DBMS_LOB |
提供對 LOB資料類型進行操作的功能 |
DBMS_OUTPUT |
處理PL/SQL塊和子程式輸出調試資訊 |
DBMS_RANDOM |
提供隨機數產生器 |
DBMS_SQL |
允許使用者使用動態 SQL |
DBMS_XMLDOM |
用DOM模型讀寫XML類型的資料 |
DBMS_XMLPARSER |
XML解析,處理XML文檔內容和結構 |
DBMS_XMLQUERY |
提供將資料轉換為 XML 類型的功能 |
DBMS_XSLPROCESSOR |
提供XSLT功能,轉換XML文檔 |
UTL_FILE |
用 PL/SQL 程式來讀寫作業系統文字檔 |
DBMS_OUTPUT包顯示 PL/SQL 塊和子程式的調試資訊。
SET SERVEROUTPUT ONBEGIN DBMS_OUTPUT.PUT_LINE(‘列印三角形‘); FOR i IN 1..9 LOOP FOR j IN 1..i LOOP DBMS_OUTPUT.PUT(‘*‘); END LOOP for_j; DBMS_OUTPUT.NEW_LINE; END LOOP for_i;END;
DBMS_LOB 包提供用於處理大型物件的過程和函數DBMS_XMLQUERY 包用於將查詢結果轉換為 XML 格式
DECLARE result CLOB; xmlstr VARCHAR2(32767); line VARCHAR2(2000); line_no INTEGER := 1;BEGIN result := DBMS_XMLQuery.getXml(‘SELECT empno, ename FROM employee‘); xmlstr := DBMS_LOB.SUBSTR(result,32767); LOOP EXIT WHEN xmlstr IS NULL; line := SUBSTR(xmlstr,1,INSTR(xmlstr,CHR(10))-1); DBMS_OUTPUT.PUT_LINE(line_no || ‘:‘ || line); xmlstr := SUBSTR(xmlstr,INSTR(xmlstr,CHR(10))+1); line_no := line_no + 1; END LOOP; END;
DBMS_RANDOM 包可用來產生8位的隨機正負整數
SET SERVEROUTPUT ON DECLARE l_num NUMBER; counter NUMBER;BEGIN counter:=1; WHILE counter <= 10 LOOP l_num := DBMS_RANDOM.RANDOM; DBMS_OUTPUT.PUT_LINE(l_num); counter:=counter+1; END LOOP;END;
UTL_FILE 包用於讀寫作業系統文字檔,操作檔案的一般過程是開啟、讀或寫、關閉
CREATE DIRECTORY TEST_DIR AS ‘C:\DEVELOP‘;
UTL_FILE 包指定檔案路徑依賴於 DIRECTORY 對象
GRANT READ, WRITE ON DIRECTORY TEST_DIR TO SCOTT;
SET SERVEROUTPUT ONDECLARE input_file UTL_FILE.FILE_TYPE; input_buffer VARCHAR2(4000);BEGIN input_file := UTL_FILE.FOPEN(‘TEST_DIR‘, ‘employees.xml‘, ‘r‘); LOOP UTL_FILE.GET_LINE(input_file,input_buffer); DBMS_OUTPUT.PUT_LINE(input_buffer); END LOOP; UTL_FILE.FCLOSE(input_file);EXCEPTION WHEN NO_DATA_FOUND THEN DBMS_OUTPUT.PUT_LINE(‘------------------‘);END;
Oracle學習筆記十四 內建程式包