叁柒設計 三七设计 Three seven design 我的学习与分享
详细信息
来自:关键字:

PHP4手册:函数库及函数(三十七) Oracle 8 资料库函式库

  December 21th,2008 22:39:58   Category : PHP+Mysql
 Click (483)

--------------------------------------------------------------------------------
 Oracle 8 资料库函式库 
--------------------------------------------------------------------------------
 


本函式库共有 15 个函式
由于本函式库都是呼叫 Oracle8 Call-Interface (OCI8) 来存取 Oracle 资料库,因此在装设 Oracle 8 Client 的 Web 伺服器上,可用本函式库存取 Oracle 7.x 或 8.x 二种版本的资料库伺服器。  


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() 
--------------------------------------------------------------------------------
 


Oracle 8 资料库函式库


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 8 中特有的新资料型态 LOB/ROWID/BFILE 等时,需要先执行 OCINewDescriptor() 函式。执行本函式成功则传回 true 值。


 
 
使用范例 


这个范例是 thies@digicol.de 所提出的
$conn = OCILogon("scott","tiger");
$stmt = OCIParse($conn,"select empno, ename from emp");
/* 使用 OCIDefineByName 要在执行 OCIExecute 前 */
OCIDefineByName($stmt,"EMPNO",&$empno);
OCIDefineByName($stmt,"ENAME",&$ename);
OCIExecute($stmt);
while (OCIFetch($stmt)) {
  echo "empno:".$empno."\n";
  echo "ename:".$ename."\n";
}
OCIFreeStatement($stmt);
OCILogoff($conn);
?> 

--------------------------------------------------------------------------------
 函式:OCIBindByName() 
--------------------------------------------------------------------------------
 


Oracle 8 资料库函式库


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 为资料的长度,若设为 -1 则使用指定的 variable 资料最大值。参数 type 可省略,其值有 OCI_B_FILE (二进位档)、OCI_B_CFILE (文字档)、OCI_B_CLOB (文字 LOB)、OCI_B_BLOB (位元 LOB) 及 OCI_B_ROWID (ROWID) 等数种。值得注意的是欲使用 Oracle 8 中特有的新资料型态 LOB/ROWID/BFILE 等时,需要先执行 OCINewDescriptor() 函式,同时必须要将 length 参数设成 -1。执行本函式成功则传回 true 值。


 
 
使用范例 


这个范例是 thies@digicol.de 所提出的,它加入三笔资料到 emp 资料表中,并使用 ROWID 来更新资料。

$conn = OCILogon("scott", "tiger");
$stmt = OCIParse($conn,"insert into emp (empno, ename) "."values (:empno,:ename) "."returning ROWID into :rid");
$data = array(1111 => "Larry", 2222 => "Bill", 3333 => "Jim");
$rowid = OCINewDescriptor($conn, OCI_D_ROWID);
OCIBindByName($stmt, ":empno", &$empno, 32);
OCIBindByName($stmt, ":ename", &$ename, 32);
OCIBindByName($stmt, ":rid", &$rowid, -1, OCI_B_ROWID);
$update = OCIParse($conn, "update emp set sal = :sal where ROWID = :rid");
OCIBindByName($update, ":rid", &$rowid, -1, OCI_B_ROWID);
OCIBindByName($update, ":sal", &$sal, 32);
$sal = 10000;
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 (1111,2222,3333)");
OCIExecute($stmt);
while (OCIFetchInto($stmt, &$arr, OCI_ASSOC)) {
  var_dump($arr);
}
OCIFreeStatement($stmt);
/* 删除刚加在 emp 资料表中的三笔资料 */
$stmt = OCIParse($conn, "delete from emp where empno in (1111,2222,3333)");
OCIExecute($stmt);
OCIFreeStatement($stmt);
OCILogoff($conn);
?> 


--------------------------------------------------------------------------------
 函式:OCILogon() 
--------------------------------------------------------------------------------
 


Oracle 8 资料库函式库


OCILogon
开启与 Oracle 的连结。

语法: int OCILogon(string username, string password, string [OCACLE_SID]);

传回值: 整数

函式种类: 资料库功能


 
 
内容说明 


本函式使 PHP 与 Oracle 建立连结。参数 username 与 password 分别为连线的帐号及密码。参数 OCACLE_SID 为资料库名称,可省略。传回值为连线的代码。

 

--------------------------------------------------------------------------------
 函式:OCILogOff() 
--------------------------------------------------------------------------------
 


Oracle 8 资料库函式库


OCILogOff
关闭与 Oracle 的连结。

语法: boolean OCILogOff(int connection);

传回值: 布林值

函式种类: 资料库功能


 
 
内容说明 


本函式使 PHP 与 Oracle 的连结结束。参数 connection 为连上 Oracle 的连线代码。传回值 true 表示成功,false 表示发生错误。

 

--------------------------------------------------------------------------------
 函式:OCIExecute() 
--------------------------------------------------------------------------------
 


Oracle 8 资料库函式库


OCIExecute
执行 Oracle 的指令区段。

语法: boolean OCIExecute(int statement, int [mode]);

传回值: 布林值

函式种类: 资料库功能


 
 
内容说明 


本函式用来执行指定的 Oracle 指令区段,执行前必须先由 OCIParse() 剖析过该区段的 SQL 语法。参数 statement 为剖析过的代码。参数 mode 可省略,其内定值为 OCI_COMMIT_ON_SUCCESS。传回值 true 表示成功,false 表示发生错误。

 

--------------------------------------------------------------------------------
 函式:OCICommit() 
--------------------------------------------------------------------------------
 


Oracle 8 资料库函式库


OCICommit
将 Oracle 的交易处理付诸实行。

语法: boolean OCICommit(int connection);

传回值: 布林值

函式种类: 资料库功能


 
 
内容说明 


本函式会将最近一次 commit/rollback 后的交易 (transaction) 做永久性的修改。参数 connection 为连上 Oracle 的连线代码。传回值 true 表示成功,false 表示发生错误。

 

--------------------------------------------------------------------------------
 函式:OCIRollback() 
--------------------------------------------------------------------------------
 


Oracle 8 资料库函式库


OCIRollback
撤消当前交易。

语法: boolean OCIRollback(int connection);

传回值: 布林值

函式种类: 资料库功能


 
 
内容说明 


本函式取消 Oracle 交易处理 (transaction) 对资料库所做的修改。参数 connection 为连上 Oracle 的连线代码。若成功则传回 true,反之传回 false。

 

--------------------------------------------------------------------------------
 函式:OCINumRows() 
--------------------------------------------------------------------------------
 


Oracle 8 资料库函式库


OCINumRows
取得受影响栏位的数目。

语法: int OCINumRows(int statement);

传回值: 整数

函式种类: 资料库功能


 
 
内容说明 


本函式传回受 UPDATE 等指令影响的栏位 (column) 数目,若使用 SELECT 等 SQL 指令则不会有影响。参数 statement 为剖析过的代码。

 

--------------------------------------------------------------------------------
 函式:OCIResult() 
--------------------------------------------------------------------------------
 


Oracle 8 资料库函式库


OCIResult
从目前列 (row) 的资料取得一栏 (column)。

语法: string OCIResult(int statement, mixed column);

传回值: 字串

函式种类: 资料库功能


 
 
内容说明 


本函式传回传回一栏资料。参数 statement 为剖析过的代码。参数 column 为栏位名。若使用新的资料形态 (ROWIDs、LOBs 与 FILEs) 传回亦均
 

--------------------------------------------------------------------------------
 函式:OCIFetch() 
--------------------------------------------------------------------------------
 


Oracle 8 资料库函式库


OCIFetch
取得传回资料的一列 (row)。

语法: int OCIFetch(int statement);

传回值: 整数

函式种类: 资料库功能


 
 
内容说明 


本函式用来取得一列非空的资料。参数 statement 为剖析过的代码。传回值 true 表示成功取回一列,false 表示本列是空的或发生其它错误。

 

--------------------------------------------------------------------------------
 函式:OCIFetchInto() 
--------------------------------------------------------------------------------
 


Oracle 8 资料库函式库


OCIFetchInto
取回 Oracle 资料放入阵列。

语法: int OCIFetchInto(array &result, int [mode]);

传回值: 整数

函式种类: 资料库功能


 
 
内容说明 


本函式将对 Oracle 取回的资料放入阵列 result 中。传回每列的栏位数目,若失败则传回 false。参数 mode 可省略,内定值为 OCI_NUM,其它还有 OCI_ASSOC、OCI_RETURN_NULLS 及 OCI_RETURN_LOBS 等。
 

--------------------------------------------------------------------------------
 函式:OCIColumnIsNULL() 
--------------------------------------------------------------------------------
 


Oracle 8 资料库函式库


OCIColumnIsNULL
测试传回行是否为空的。

语法: boolean OCIColumnIsNULL(int stmt, mixed column);

传回值: 布林值

函式种类: 资料库功能


 
 
内容说明 


本函式用来测试传回的行 (column) 是否为空值 (NULL)。传回 true 表示为空值。

 

--------------------------------------------------------------------------------
 函式:OCIColumnSize() 
--------------------------------------------------------------------------------
 


Oracle 8 资料库函式库


OCIColumnSize
取得栏位型态的大小。

语法: int OCIColumnSize(int stmt, mixed column);

传回值: 整数

函式种类: 资料库功能


 
 
内容说明 


本函式可以取得栏位 (column) 型态 (type) 的大小。

 

--------------------------------------------------------------------------------
 函式:OCINewDescriptor() 
--------------------------------------------------------------------------------
 


Oracle 8 资料库函式库


OCINewDescriptor
初始新的 LOB/FILE 描述。

语法: string OCINewDescriptor(int connection , int [type]);

传回值: 字串

函式种类: 资料库功能


 
 
内容说明 


本函式用来初始化新的 LOB/FILE 描述值。

 

--------------------------------------------------------------------------------
 函式:OCIParse() 
--------------------------------------------------------------------------------
 


Oracle 8 资料库函式库


OCIParse
分析 SQL 语法。

语法: int OCIParse(int connection, string query);

传回值: 整数

函式种类: 资料库功能


 
 
内容说明 


本函式可用来分析 SQL 语法或是 PL/SQL 区段是否有错误。参数 connection 为连线代码。参数 query 为 SQL 指令字串。

[ 资讯评论 ]
暂时没有任何评论!
[ 提交评论 ]
请选择表情
  • 昵称:
  • *
  • 验证码:
  • *点击更换验证码
  • 尚能输入个字符
申明:本网站部分分享内容来自网络,如有侵权请及时与我联系,谢谢,另网友评论仅代表个人观点,与本站立场无关,如果在评论中发表违反我国任何法律的,请即时与我们联系(QQ:77132915),我们将立即予以删除. [ 注:提交评论后,通过审核后方能在网站上显示!]