位置: 编程技术 - 正文

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函数

  • 出口免税产品如何缴纳附加税
  • 货物运输发票抵税多少
  • 结转固定资产清理的会计科目
  • 固定总价合同中,承包人承担的价格风险
  • 等额本息还款的特点
  • 工业企业会计错账处理方法有哪些
  • 跨年度借款利息的税务处理怎么做?
  • 如何减少资产负债表上的资本公积
  • 视同销售可以抵扣销项税吗?
  • 机打发票多久可以作废
  • 租赁场地费入什么科目
  • 代扣代缴个人所得税手续费是否缴纳增值税
  • 新企业所得税法规定的企业包括
  • 汇总转账凭证可以是一借多贷
  • 回购股票时的会计分录
  • 简易计税开票开成了一般计税的税率会比对不通过吗
  • 委托加工应税消费品收回后直接销售
  • 补缴的附加税怎么入账
  • 收购公司款项的支付是利好还是利差
  • win7不能进系统怎么办
  • 教你如何在白桦树上采集桦树汁
  • 电脑重装win7系统后无法连接网络
  • 什么电脑系统比较好
  • 联想一体机如何调节屏幕亮度
  • retrorun.exe - retrorun有什么用 是什么进程
  • PHP:pg_lo_open()的用法_PostgreSQL函数
  • vue3自定义指令
  • PHP:pcntl_fork()的用法_PCNTL函数
  • 固定资产当月出售还要计提折旧吗
  • 购买二手车要缴税吗
  • thinkphp smarty
  • 小型微利企业减免所得税计算公式
  • 身份证php编写
  • 购买税控盘后要交税吗
  • 正则表达式大全(整理版)
  • 金碟软件如何查看明细账
  • es6对象扩展运算符
  • 注意力机制 q k v
  • 比较好的微信名称有哪些
  • 折扣销售增值税计算例题
  • 股权转让怎么查
  • 工程施工预缴增值税
  • 公司费用计入什么科目
  • mongodb主备配置
  • 汽车租赁发票账务怎么开
  • PostgreSQL教程(十五):系统表详解
  • 新会计准则物业公司计提应收账款分录
  • 小规模纳税人企业所得税2023
  • 生产成本和营业成本的区别和联系
  • 开发票给别人该如何收取税点?
  • 坏账准备?
  • 关于餐饮行业
  • 冲销预付账款怎么填记账凭证
  • 外购设备的会计分录
  • 机票开的个人的票是什么
  • 成品油发票的勾选方法
  • 餐费补贴属于工资还是福利费
  • 发票金额小于实付金额会计分录
  • 备查账目
  • sqlserver dbcc
  • win8系统升级到win 10
  • windows10创意者更新
  • 无线网卡搜索不到无线网
  • 手动防止Ping攻击方法(无需防火墙)
  • mac怎么分区硬盘分区
  • linux系统中软件包分类
  • macos dock
  • make:arm-linux- conmand not found错误处理探讨
  • 系统ui怎么关闭
  • win7格式化怎么操作?
  • android app 源码
  • android secure
  • opengl获取鼠标位置
  • 下列关于android的说法中,错误的是
  • nginx服务器日志
  • jquery教程chm
  • android auto翻译
  • pygame 安装
  • js遍历foreach
  • 国家医保平台查不到住院记录
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设