位置: 编程技术 - 正文

PHP:oci_new_connect()的用法_Oracle函数

编辑:rootadmin
oci_new_connect

推荐整理分享PHP:oci_new_connect()的用法_Oracle函数,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

(PHP 5, PECL OCI8 >= 1.1.0)

oci_new_connect — 建定一个到 Oracle 服务器的新连接

说明 resource oci_new_connect ( string $username , string $password [, string $db [, string $charset [, int $session_mode ]]] )

oci_new_connect() 创建一个到 Oracle 服务器的新连接并登录。与 oci_connect() 和 oci_pconnect() 不同,oci_new_connect() 不会缓冲连接,总是会返回一个全新的刚打开的连接句柄。这在应用程序需要在两组查询之间实现事务隔离很有用。

可选的第三个参数可以是本地 Oracle 实例的名字或者是在 tnsnames.ora 的条目中的名字。如果没有指定第三个参数, PHP 使用环境变量 ORACLE_SID 和 TWO_TASK 来分别确定本地 Oracle 实例的名字和 tnsnames.ora 的位置。

session_mode 参数自版本 1.1 起可用并接受如下值:OCI_DEFAULT,OCI_SYSOPER 和 OCI_SYSDBA。如果指定了 OCI_SYSOPER 或 OCI_SYSDBA 其中之一,oci_new_connect() 将尝试使用外部认证信息建立特权连接。特权连接默认被禁止。要启用,需要将 oci8.privileged_connect 设为 On。

使用 Oracle客户端库来确定字符集。字符集不需要与数据库的字符集相匹配。如果不匹配,Oracle会尽可能地将数据从数据库字符集进行转换。因为依赖于字符集,可能不能给出可用的结果。转换也增加一些时间开销。

如果不指定,Oracle 客户端用 NLS_LANG 环境变量来决定字符集。

传递此参数可减少连接时间。

下面例子演示了怎样隔离连接。

Example #1 oci_new_connect() 例子

<?phpecho"<html><pre>";$db="";$c1=oci_connect("scott","tiger",$db);$c2=oci_new_connect("scott","tiger",$db);functioncreate_table($conn){$stmt=oci_parse($conn,"createtablescott.hallo(testvarchar2())");oci_execute($stmt);echo$conn."createdtablenn";}functiondrop_table($conn){$stmt=oci_parse($conn,"droptablescott.hallo");oci_execute($stmt);echo$conn."droppedtablenn";}functioninsert_data($conn){$stmt=oci_parse($conn,"insertintoscott.hallovalues('$conn'||''||to_char(sysdate,'DD-MON-YYHH:MI:SS'))");oci_execute($stmt,OCI_DEFAULT);echo$conn."insertedhallonn";}functiondelete_data($conn){$stmt=oci_parse($conn,"deletefromscott.hallo");oci_execute($stmt,OCI_DEFAULT);echo$conn."deletedhallonn";}functioncommit($conn){oci_commit($conn);echo$conn."committednn";}functionrollback($conn){oci_rollback($conn);echo$conn."rollbacknn";}functionselect_data($conn){$stmt=oci_parse($conn,"select*fromscott.hallo");oci_execute($stmt,OCI_DEFAULT);echo$conn."----selectingnn";while(oci_fetch($stmt)){echo$conn."<".oci_result($stmt,"TEST").">nn";}echo$conn."----donenn";}create_table($c1);insert_data($c1);select_data($c1);select_data($c2);rollback($c1);select_data($c1);select_data($c2);insert_data($c2);commit($c2);select_data($c1);delete_data($c1);select_data($c1);select_data($c2);commit($c1);select_data($c1);select_data($c2);drop_table($c1);echo"</pre></html>";?>

oci_new_connect() 在出错时返回 FALSE。

Note:

在 PHP 5.0.0 之前的版本必须使用 ocinlogon() 替代本函数。该函数名仍然可用,为向下兼容作为 oci_new_connect() 的别名。不过其已被废弃,不推荐使用。

参见 oci_connect() 和 oci_pconnect()。

参数

username

The Oracle user name.

password PHP:oci_new_connect()的用法_Oracle函数

The password for username.

connection_string

包含要连接的Oracle 实例。可以是 »Easy Connect 串,或是tnsnames.ora 文件中的连接名,或是本地 Oracle 实例名。

如果不指定,PHP 使用环境变量来确定连接的 Oracle 实例,诸如 TWO_TASK(Linux 下)或 LOCAL(Windows 下)与 ORACLE_SID 等。

要使用 Easy Connect 命名方法,PHP 必须与 Oracle g 或更高版本的客户端库进行链接。Oracle g 的 Easy Connect 串格式:[//]host_name[:port][/service_name]。Oracle g 则为:[//]host_name[:port][/service_name][:server_type][/instance_name]。服务名可在数据库服务器机器上运行 Oracle 实用程序 lsnrctl status 找到。

tnsnames.ora 文件可在 Oracle Net 查找路径中,此路径包括 $ORACLE_HOME/network/admin 和 /etc。 另一种方法是设置 TNS_ADMIN 以便通过 $TNS_ADMIN/tnsnames.ora 来读取。表确认 web 守护进程可读取此文件。

character_set

使用 Oracle客户端库来确定字符集。字符集不需要与数据库的字符集相匹配。如果不匹配,Oracle会尽可能地将数据从数据库字符集进行转换。因为依赖于字符集,可能不能给出可用的结果。转换也增加一些时间开销。

如果不指定,Oracle 客户端用 NLS_LANG 环境变量来决定字符集。

传递此参数可减少连接时间。

session_mode

此参数在 PHP 5(PECL OCI.1)版本开始可用,并收受下列值:OCI_DEFAULT,OCI_SYSOPER和 OCI_SYSDBA。如为OCI_SYSOPER 或 OCI_SYSDBA其中之一,此函数将会使用外部的证书建立有特权的连接。有特权的连接默认是禁用的。需要将oci8.privileged_connect设为 On 来启用。

PHP 5.3(PECL OCI8 1.3.4)引进了 OCI_CRED_EXT 模式值。使用外部或操作系统认证必需在 Oracle 数据库中进行配置。OCI_CRED_EXT 标志只可用于用户为 "/",密码为空的情况。oci8.privileged_connect 可为 On 或 Off。

OCI_CRED_EXT 可与 OCI_SYSOPER 或 OCI_SYSDBA 模式组合使用。

OCI_CRED_EXT 由于安全的原因不支持 Windows 系统。

返回值

Returns a connection identifier or FALSE on error.

范例

The following demonstrates how you can separate connections.

Example #2 oci_new_connect() example

<?phpecho"<html><pre>";$db="";$c1=oci_connect("scott","tiger",$db);$c2=oci_new_connect("scott","tiger",$db);functioncreate_table($conn){$stmt=oci_parse($conn,"createtablescott.hallo(testvarchar2())");oci_execute($stmt);echo$conn."createdtablenn";}functiondrop_table($conn){$stmt=oci_parse($conn,"droptablescott.hallo");oci_execute($stmt);echo$conn."droppedtablenn";}functioninsert_data($conn){$stmt=oci_parse($conn,"insertintoscott.hallovalues('$conn'||''||to_char(sysdate,'DD-MON-YYHH:MI:SS'))");oci_execute($stmt,OCI_DEFAULT);echo$conn."insertedhallonn";}functiondelete_data($conn){$stmt=oci_parse($conn,"deletefromscott.hallo");oci_execute($stmt,OCI_DEFAULT);echo$conn."deletedhallonn";}functioncommit($conn){oci_commit($conn);echo$conn."committednn";}functionrollback($conn){oci_rollback($conn);echo$conn."rollbacknn";}functionselect_data($conn){$stmt=oci_parse($conn,"select*fromscott.hallo");oci_execute($stmt,OCI_DEFAULT);echo$conn."----selectingnn";while(oci_fetch($stmt)){echo$conn."<".oci_result($stmt,"TEST").">nn";}echo$conn."----donenn";}create_table($c1);insert_data($c1);select_data($c1);select_data($c2);rollback($c1);select_data($c1);select_data($c2);insert_data($c2);commit($c2);select_data($c1);delete_data($c1);select_data($c1);select_data($c2);commit($c1);select_data($c1);select_data($c2);drop_table($c1);echo"</pre></html>";?>

注释

Note:

In PHP versions before 5.0.0 you must use ocinlogon() instead. 在当前版本中,旧的函数名还可以被使用,但已经被废弃并不建议使用。

参见

oci_connect() - 建立一个到 Oracle 服务器的连接 oci_pconnect() - 使用一个持久连接连到 Oracle 数据库

PHP:oci_new_collection()的用法_Oracle函数 oci_new_collection(PHP5,PECLOCI8=1.1.0)oci_new_collection分配新的collection对象说明OCI-Collectionoci_new_collection(resource$connection,string$tdo[,string$schema])分配一个新的collection

PHP:oci_new_cursor()的用法_Oracle函数 oci_new_cursor(PHP5,PECLOCI8=1.1.0)oci_new_cursor分配并返回一个新的游标(语句句柄)说明resourceoci_new_cursor(resource$connection)oci_new_cursor()在指定的连接上分配一个

PHP:oci_lob_is_equal()的用法_Oracle函数 oci_lob_is_equal(PHP5,PECLOCI8=1.1.0)oci_lob_is_equalComparestwoLOB/FILElocatorsforequality说明booloci_lob_is_equal(OCI-Lob$lob1,OCI-Lob$lob2)ComparestwoLOB/FILElocators.参数lob1ALOBidentifier.lob

标签: PHP:oci_new_connect()的用法_Oracle函数

本文链接地址:https://www.jiuchutong.com/biancheng/275245.html 转载请保留说明!

上一篇:PHP:oci_internal_debug()的用法_Oracle函数

下一篇:PHP:oci_new_collection()的用法_Oracle函数

  • 股东向公司借款超过一年不还
  • 一般风险准备是留存收益吗
  • 教育培训行业税负率是多少
  • 固定资产分期付款会计处理
  • 两个账户往来款怎么做现金流量表
  • 申报工资总额填错了
  • 货币资金项目应根据账户的期末余额合计填列
  • 企业怎么挑选计提折旧方式方法
  • 新领的发票怎么导入uk开票系统
  • 高温费计税吗
  • 会计发票怎么样粘贴,记账凭证也要粘上吗
  • 事业单位个税可以抵扣吗
  • 营改增后个人所得税计税依据实例
  • 赠送给客户
  • 进项转出滞纳金规定
  • 单次劳务费税率
  • 旅游景区税收标准
  • 广告制作费怎么入账
  • 领用原材料安装固定资产
  • 企业债券收入要在所得税前扣除吗
  • 进口货物有进项税吗
  • 房地产土地增值税计税依据
  • 为什么贷款利息变高了
  • 无法偿还的应付款项予以转账
  • 欧拉操作系统和龙蜥哪个好用
  • 在win7系统中,怎么把D盘里的文件移到C盘里?
  • 上月多计提的所得税怎么做分录
  • dghm.exe是什么程序
  • 不属于职工福利费的是抚恤费
  • 固定资产八大类别
  • 月末一次加权平均和移动加权平均的区别
  • yii2权威指南
  • yarn安装路径
  • 出口货物应退增值税如何计算
  • 利用php生成静态数据
  • 年底所得税怎么算
  • 进项转出分录处理
  • EOFError:EOF when reading a line
  • mongodb索引存储方式
  • 11-ElementUI
  • 报废的设备属于什么
  • 固定资产原值增加当月计提折旧吗
  • 销售中介费一般收多少
  • 项目投标代理服务方案
  • 怎么算股本溢价
  • 上月做了未开票收入,这月开了票怎么报税
  • 固定资产清理账户期末有余额吗
  • 结转未交增值税为什么是零
  • 财务常见问题有哪些
  • 高新技术企业财务指标
  • 发票红冲怎么回事
  • 销售做不动 应该做什么
  • 新会计准则经营租赁
  • 企业股东的出资方式
  • 生产成本和主营业务收入的关系
  • 新公司要建哪些项目
  • 原始凭证怎么粘
  • sqlserver 17051解决方案
  • 怎么用u盘装驱动
  • ubuntu18.04更新到20.04
  • 电脑待机状态下载会继续吗
  • 重装系统东西
  • vrvarp.exe是什么
  • 如何查看电脑型号及配置
  • Win10系统如何开启全部权限
  • windows8笔记本电脑
  • windows8装.NET 3.5时出现0x800F0906错误解决方案
  • windows 10运行
  • css3兼容性问题
  • js定义数字
  • linux多进程编程实例
  • shell脚本判断两个数大小
  • js标志
  • nvm下载安装
  • jquery 插件写法
  • 河南普通发票查询真伪查询系统
  • 沧州市养老保险局官网
  • 华为领导班子成员名单
  • 党建与内控合规风险防范相融合
  • 个体户不用开发票只纳税和记账的话还会罚款吗?
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设