位置: 编程技术 - 正文

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

  • 企业所得税视同销售的会计处理是?
  • 符合简易征收的条件
  • 进口产品销售需要什么资质
  • 管理费用怎么结转成本
  • 非居民企业出租境内不动产
  • 企业开办时间是什么意思
  • 租入厂房改建折旧年限
  • 财务报表其他应付款为负数
  • 银行存款一直没动会怎样
  • 当月有待发货如何退货
  • 企业租车费用怎么处理方法
  • 企业发生的销售折让
  • 倒增值税发票过程
  • 收到培训机构的电话骚扰该怎么办?
  • 公司支付个人劳务
  • 外地出差的餐费住宿费是不是都计入差旅费
  • 讲师费发票开票科目
  • 科研项目经费怎么填
  • 吸收合并后被合并的公司
  • 制造费用分摊的账务处理怎么做?
  • 物业营改增什么时候开始
  • 财报申报逾期可不可以补报
  • 可以在企业所得税税前扣除的税金有
  • 清算期间未申报债权
  • 按产品的品种型号规格规定的计划
  • 企业所得税季度申报表季度平均值
  • 房地产转让的条件
  • 进口关税和增值税
  • macos连接wifi无法上网
  • 上一年度的费用入账需要分摊吗
  • sbsetup.exe - sbsetup是什么进程 有什么用
  • 劳务费支出会计处理
  • 甲产品生产耗用a材料10000千克,单位成本
  • html+css+javascript编程入门指南
  • 全卷积网络fcn详解
  • VUE-CLI/VUE-ROUTER
  • php经典面试题及答案
  • 现金和现金等价物包括哪些
  • 机关事业单位以外包服务方式长期用工
  • python文件间传递参数
  • 缴纳印花税需要带公章吗
  • sql server 2008 r2 express 精简版与企业版的区别
  • 固定资产直接进费用表示表示一次性计提折旧
  • 收据所得税前扣除
  • 银行利息支出税率是多少
  • 企业实收资本与实缴资本
  • 工业企业成本一般占收入的比例
  • 坏账准备的账务处理T型
  • 销售净利率指标的计算是净利润与资产平均余额的比值
  • 接受母公司捐赠现金分录
  • 暂估入库结转成本后如何冲红
  • 服装租赁费的税率是多少
  • 研发费用 汇算清缴
  • 归还银行的贷款会计分录
  • 借主营业务成本贷应付账款
  • 为什么看科目四看不进去呀
  • winxp更新到win10
  • linux解析命令
  • centos的命令行界面输入
  • 如何查看freenass密码
  • 创建svn库
  • win10系统如何查看激活状态
  • Win7系统打开蓝牙
  • linux apt apt-get
  • win7系统出现蓝屏
  • 关闭默认共享和共享文件夹
  • jquery 引入js
  • node.js教程详细
  • ml命令
  • jquery+ajax实现注册实时验证实例详解
  • Node.js中的事件循环是什么
  • js函数调用常用字符串
  • pythoni脚本
  • javascript的用法
  • 做网页的流程与步骤
  • 工商跟税务的区别
  • 北京增值税普通发票图片
  • 长春国税局科员工资是多少
  • 乡镇四所是指哪些所
  • 日本海淘推荐
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设