文字

oci_new_connect

(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_SIDTWO_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() 例子

<?php
echo  "<html><pre>" ;
$db  "" ;

$c1  oci_connect ( "scott" "tiger" $db );
$c2  oci_new_connect ( "scott" "tiger" $db );

function 
create_table ( $conn )
{
  
$stmt  oci_parse ( $conn "create table scott.hallo (test
varchar2(64))"
);
  
oci_execute ( $stmt );
  echo 
$conn  " created table\n\n" ;
}

function 
drop_table ( $conn )
{
  
$stmt  oci_parse ( $conn "drop table scott.hallo" );
  
oci_execute ( $stmt );
  echo 
$conn  " dropped table\n\n" ;
}

function 
insert_data ( $conn )
{
  
$stmt  oci_parse ( $conn "insert into scott.hallo
            values('
$conn ' || ' ' || to_char(sysdate,'DD-MON-YY HH24:MI:SS'))" );
  
oci_execute ( $stmt OCI_DEFAULT );
  echo 
$conn  " inserted hallo\n\n" ;
}

function 
delete_data ( $conn )
{
  
$stmt  oci_parse ( $conn "delete from scott.hallo" );
  
oci_execute ( $stmt OCI_DEFAULT );
  echo 
$conn  " deleted hallo\n\n" ;
}

function 
commit ( $conn )
{
  
oci_commit ( $conn );
  echo 
$conn  " committed\n\n" ;
}

function 
rollback ( $conn )
{
  
oci_rollback ( $conn );
  echo 
$conn  " rollback\n\n" ;
}

function 
select_data ( $conn )
{
  
$stmt  oci_parse ( $conn "select * from scott.hallo" );
  
oci_execute ( $stmt OCI_DEFAULT );
  echo 
$conn  "----selecting\n\n" ;
  while (
oci_fetch ( $stmt )) {
    echo 
$conn  " <"  oci_result ( $stmt "TEST" ) .  ">\n\n" ;
  }
  echo 
$conn  "----done\n\n" ;
}

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

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 10g 或更高版本的客户端库进行链接。Oracle 10g 的 Easy Connect 串格式:[//]host_name[:port][/service_name]。Oracle 11g 则为:[//]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 OCI8 1.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 可为 OnOff

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

<?php
echo  "<html><pre>" ;
$db  "" ;

$c1  oci_connect ( "scott" "tiger" $db );
$c2  oci_new_connect ( "scott" "tiger" $db );

function 
create_table ( $conn )
{
  
$stmt  oci_parse ( $conn "create table scott.hallo (test
varchar2(64))"
);
  
oci_execute ( $stmt );
  echo 
$conn  " created table\n\n" ;
}

function 
drop_table ( $conn )
{
  
$stmt  oci_parse ( $conn "drop table scott.hallo" );
  
oci_execute ( $stmt );
  echo 
$conn  " dropped table\n\n" ;
}

function 
insert_data ( $conn )
{
  
$stmt  oci_parse ( $conn "insert into scott.hallo
            values('
$conn ' || ' ' || to_char(sysdate,'DD-MON-YY HH24:MI:SS'))" );
  
oci_execute ( $stmt OCI_DEFAULT );
  echo 
$conn  " inserted hallo\n\n" ;
}

function 
delete_data ( $conn )
{
  
$stmt  oci_parse ( $conn "delete from scott.hallo" );
  
oci_execute ( $stmt OCI_DEFAULT );
  echo 
$conn  " deleted hallo\n\n" ;
}

function 
commit ( $conn )
{
  
oci_commit ( $conn );
  echo 
$conn  " committed\n\n" ;
}

function 
rollback ( $conn )
{
  
oci_rollback ( $conn );
  echo 
$conn  " rollback\n\n" ;
}

function 
select_data ( $conn )
{
  
$stmt  oci_parse ( $conn "select * from scott.hallo" );
  
oci_execute ( $stmt OCI_DEFAULT );
  echo 
$conn  "----selecting\n\n" ;
  while (
oci_fetch ( $stmt )) {
    echo 
$conn  " <"  oci_result ( $stmt "TEST" ) .  ">\n\n" ;
  }
  echo 
$conn  "----done\n\n" ;
}

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 数据库
上一篇: 下一篇: