分享
 
 
 

Oracle 8 数据库函数库

王朝oracle·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

由于本函数库都是调用 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

让 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 所提出的

<?php

$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

让动态 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 来更新资料。

<?php

$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 的链接。

语法: 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_COMM99v_ON_SUCCESS。返回值 true 表示成功,false 表示发生错误。

OCICommit

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

语法: boolean OCICommit(int connection);

返回值: 布尔值

函数种类: 数据库功能

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

OCIRollback

撤消当前交易。

语法: boolean OCIRollback(int connection);

返回值: 布尔值

函数种类: 数据库功能

内容说明: 本函数取消 Oracle 交易处理 (transaction) 对数据库所做的修改

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有