Oracle學習筆記十四 內建程式包

來源:互聯網
上載者:User

標籤:

  • 擴充資料庫的功能
  • 為 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學習筆記十四 內建程式包

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.