熱點推薦:
您现在的位置: 電腦知識網 >> 編程 >> Oracle >> 正文

Oracle 8 數據庫函數庫的列舉與具體介紹

2013-11-13 16:08:07  來源: Oracle 

  OCIDefineByName: 讓 SELECT 指令可使用 PHP 變量
  OCIBindByName: 讓動態 SQL 可使用 PHP 變量
  OCILogon: 打開與 Oracle 的鏈接
  OCILogOff: 關閉與 Oracle 的鏈接
  OCIExecute: 執行 Oracle 的指令部分
  OCICommit: 將 Oracle 的交易處理付諸實行
  OCIRollback: 撤消當前交易
  OCINumRows: 取得受影響字段的數目
  OCIResult: 從目前列 (row) 的資料取得一欄 (column)
  OCIFetch: 取得返回資料的一列 (row)
  OCIFetchInto: 取回 Oracle 資料放入數組
  OCIColumnIsNULL: 測試返回行是否為空的
  OCIColumnSize: 取得字段類型的大小
  OCINewDescriptor: 初始新的 LOB/FILE 描述
  OCIParse: 分析 SQL 語法
  
  OCIDefineByName
  讓 SELECT 指令可使用 PHP 變量
  語法: boolean OCIDefineByName(int stmt string ColumnName mixed &variable int [type]);
  返回值: 布爾值
  函數種類: 數據庫功能
  內容說明: 本函數用來定義指定的 PHP 變量使其能供 SQL 指令中的 SELECT 指令使用在大小寫的問題上要注意一下因為 Oracle 數據庫中的字段名稱其實都是大寫的名字參數 stmt 是經過 Oracle 解析 (OCIParse) 後的字符串指針參數 ColumnName 是 Oracle 資料表上的字段名稱參數 variable 前面一定要加 & 符號表 PHP 變量位址參數 type 通常省略治募注意的是欲使用 Oracle 中特有的新資料類型 LOB/ROWID/BFILE 等時需要先執行 OCINewDescriptor() 函數執行本函數成功則返回 true 值
  使用范例
  這個范例是 thies@digicolde 所提出的
  <?php
  $conn = OCILogon(scotttiger);
  $stmt = OCIParse($connselect empno ename from emp);
  /* 使用 OCIDefineByName 要在執行 OCIExecute 前 */
  OCIDefineByName($stmtEMPNO&$empno);
  OCIDefineByName($stmtENAME&$ename);
  OCIExecute($stmt);
  while (OCIFetch($stmt)) {
  echo empno:$empno\n;
  echo ename:$ename\n;
  }
  OCIFreeStatement($stmt);
  OCILogoff($conn);
  ?>
  
  OCIBindByName
  讓動態 SQL 可使用 PHP 變量
  語法: boolean OCIBindByName(int stmt string ph_name mixed &variable int length int [type]);
  返回值: 布爾值
  函數種類: 數據庫功能
  內容說明: 本函數用來定義指定的 PHP 變量使其能供動態的 SQL 指令 (Oracle Placeholder) 使用在大小寫的問題上要注意一下因為 Oracle 數據庫中的字段名稱其實都是大寫的名字參數 stmt 是經過 Oracle 解析 (OCIParse) 後的字符串指針參數 ph_name 即為欲供動態 SQL 指令所使用的變量參數 variable 前面一定要加 & 符號表 PHP 變量位址參數 length 為資料的長度若設為 則使用指定的 variable 資料最大值參數 type 可省略其值有 OCI_B_FILE (二進位文件)OCI_B_CFILE (文字文件)OCI_B_CLOB (文字 LOB)OCI_B_BLOB (位 LOB) 及 OCI_B_ROWID (ROWID) 等數種治募注意的是欲使用 Oracle 中特有的新資料類型 LOB/ROWID/BFILE 等時需要先執行 OCINewDescriptor() 函數同時必須要將 length 參數設成 執行本函數成功則返回 true 值
  使用范例
  這個范例是 thies@digicolde 所提出的它加入三筆資料到 emp 資料表中並使用 ROWID 來更新資料
  <?php
  $conn = OCILogon(scott tiger);
  $stmt = OCIParse($conninsert into emp (empno ename) values (:empno:ename) returning ROWID into :rid);
  $data = array( => Larry => Bill => Jim);
  $rowid = OCINewDescriptor($conn OCI_D_ROWID);
  OCIBindByName($stmt :empno &$empno );
  OCIBindByName($stmt :ename &$ename );
  OCIBindByName($stmt :rid &$rowid OCI_B_ROWID);
  $update = OCIParse($conn update emp set sal = :sal where ROWID = :rid);
  OCIBindByName($update :rid &$rowid OCI_B_ROWID);
  OCIBindByName($update :sal &$sal );
  $sal = ;
  while (list($empno $ename) = each($data)) {
  OCIExecute($stmt);
  OCIExecute($update);
  }
  $rowid>free();
  OCIFreeStatement($update);
  OCIFreeStatement($stmt);
  $stmt = OCIParse($conn select * from emp where empno in ());
  OCIExecute($stmt);
  while (OCIFetchInto($stmt &$arr OCI_ASSOC)) {
  var_dump($arr);
  }
  OCIFreeStatement($stmt);
  /* 刪除剛加在 emp 資料表中的三筆資料 */
  $stmt = OCIParse($conn delete from emp where empno in ());
  OCIExecute($stmt);
  OCIFreeStatement($stmt);
  OCILogoff($conn);
  ?>
  
  OCILogon
  打開與 Oracle 的鏈接
  語法: int OCILogon(string username string password string [OCACLE_SID]);
  返回值: 整數
  函數種類: 數據庫功能
  內容說明: 本函數使 PHP 與 Oracle 建立鏈接參數 username 與 password 分別為連接的帳號及密碼參數 OCACLE_SID 為數據庫名稱可省略返回值為連接的代碼
  
  OCILogOff
  關閉與 Oracle 的鏈接
  語法: boolean OCILogOff(int connection);
  返回值: 布爾值
  函數種類: 數據庫功能
  內容說明: 本函數使 PHP 與 Oracle 的鏈接結束參數 connection 為連上 Oracle 的連接代碼返回值 true 表示成功false 表示發生錯誤
  
  OCIExecute
  執行 Oracle 的指令部分
  語法: boolean OCIExecute(int statement int [mode]);
  返回值: 布爾值
  函數種類: 數據庫功能
  內容說明: 本函數用來執行指定的 Oracle 指令部分執行前必須先由 OCIParse() 解析過該部分的 SQL 語法參數 statement 為解析過的代碼參數 mode 可省略其默認值為 OCI_COMMIT_ON_SUCCESS返回值 true 表示成功false 表示發生錯誤
  
  OCICommit
  將 Oracle 的交易處理付諸實行
  語法: boolean OCICommit(int connection);
  返回值: 布爾值
  函數種類: 數據庫功能
  內容說明: 本函數會將最近一次 commit/rollback 後的交易 (transaction) 做永久性的修改參數 connection 為連上 Oracle 的連接代碼返回值 true 表示成功false 表示發生錯誤
  
  OCIRollback
  撤消當前交易
  語法: boolean OCIRollback(int connection);
  返回值: 布爾值
  函數種類: 數據庫功能
  內容說明: 本函數取消 Oracle 交易處理 (transaction) 對數據庫所做的修改參數 connection 為連上 Oracle 的連接代碼若成功則返回 true反之返回 false
  
  OCINumRows
  取得受影響字段的數目
  語法: int OCINumRows(int statement);
  返回值: 整數
  函數種類: 數據庫功能
  內容說明: 本函數返回受 UPDATE 等指令影響的字段 (column) 數目若使用 SELECT 等 SQL 指令則不會有影響參數 statement 為解析過的代碼
  
  OCIResult
  從目前列 (row) 的資料取得一欄 (column)
  語法: string OCIResult(int statement mixed column);
  返回值: 字符串
  函數種類: 數據庫功能
  內容說明: 本函數返回返回一欄資料參數 statement 為解析過的代碼參數 column 為字段名若使用新的資料類型 (ROWIDsLOBs 與 FILEs) 返回亦均為字符串
  
  OCIFetch
  取得返回資料的一列 (row)
  語法: int OCIFetch(int statement);
  返回值: 整數
  函數種類: 數據庫功能
  內容說明: 本函數用來取得一列非空的資料參數 statement 為解析過的代碼返回值 true 表示成功取回一列false 表示本列是空的或發生其它錯誤
  
  OCIFetchInto
  取回 Oracle 資料放入數組
  語法: int OCIFetchInto(array &result int [mode]);
  返回值: 整數
  函數種類: 數據庫功能
  內容說明: 本函數將對 Oracle 取回的資料放入數組 result 中返回每列的字段數目若失敗則返回 false參數 mode 可省略默認值為 OCI_NUM其它還有 OCI_ASSOCOCI_RETURN_NULLS 及 OCI_RETURN_LOBS 等
  
  OCIColumnIsNULL
  測試返回行是否為空的
  語法: boolean OCIColumnIsNULL(int stmt mixed column);
  返回值: 布爾值
  函數種類: 數據庫功能
  內容說明: 本函數用來測試返回的行 (column) 是否為空值 (NULL)返回 true 表示為空值
  
  OCIColumnSize
  取得字段類型的大小
  語法: int OCIColumnSize(int stmt mixed column);
  返回值: 整數
  函數種類: 數據庫功能
  內容說明: 本函數可以取得字段 (column) 類型 (type) 的大小
  
  OCINewDescriptor
  初始新的 LOB/FILE 描述
  語法: string OCINewDescriptor(int connection int [type]);
  返回值: 字符串
  函數種類: 數據庫功能
  內容說明: 本函數用來初始化新的 LOB/FILE 描
From:http://tw.wingwit.com/Article/program/Oracle/201311/17870.html
    推薦文章
    Copyright © 2005-2013 電腦知識網 Computer Knowledge   All rights reserved.