Deprecated: The each() function is deprecated. This message will be suppressed on further calls in /home/zhenxiangba/zhenxiangba.com/public_html/phproxy-improved-master/index.php on line 456
PHP: oci_connect - Manual
[go: Go Back, main page]

PHP  
downloads | documentation | faq | getting help | mailing lists | reporting bugs | php.net sites | links | my php.net 
search for in the  
<oci_commitoci_define_by_name" width="11" height="7"/>
view the version of this page
Last updated: Sun, 07 May 2006

oci_connect

(PHP 5)

oci_connect -- Oracle サーバへの接続を確立する

説明

resource oci_connect ( string username, string password [, string db [, string charset [, int session_mode]]] )

oci_connect() は他のほとんどの OCI コールで必要な 接続 ID を返します。 オプションの3番目のパラメータには、ローカルOracleインスタンスの名前か tnsnames.ora における接続先のエントリ名を指定することができます。 オプションの3番目のパラメータが指定されない場合、 PHP は接続先のデータベースを決定するために環境変数 ORACLE_SID (Oracle インスタンス)または TWO_TASK (tnsnames.ora) を使用します。

パラメータ session_mode はバージョン 1.1 からり用可能で、次の値を受け付けます: OCI_DEFAULT, OCI_SYSOPER, OCI_SYSDBAOCI_SYSOPER もしくは OCI_SYSDBA のいずれかが指定された場合、 oci_connect() は外部の信用を利用して 権限付きの接続を確立しようとします。 デフォルトでは権限付きの接続は無効です。有効にするためには、oci8.privileged_connect をオンにしてください。

注意: もし PHP を Oracle Instant Client と併用している場合、 次に解説されている簡単な接続ネーミングメソッドを使用することができます: http://download-west.oracle.com/docs/cd/B12037_01/network.101/b10775/naming.htm#i498306 。 基本的にデータベース名として "//db_host[:port]/database_name" を指定できることを意味します。しかし、 古いネーミング方法を使用したい場合、ORACLE_HOME もしくは TNS_ADMIN のいずれかを設定 しなければなりません

注意: 同じパラメータを使用して 2 回目やそれ以降に oci_connect() がコールされた場合、 最初のコールで返された接続ハンドルを返します。 これは 1 つのハンドルに対して発行されたクエリは、 他のハンドルにも適用されることを意味します。なぜなら、 これらは 同じ ハンドルだからです。 この動作は以下の例 1 で例示されています。 もしトランザクション的にお互い独立した 2 つのハンドルが必要な場合、 oci_new_connect() を使用してください。

Oracle サーバのバージョン 9.2 以降を使用している場合、新規接続を確立する際に charset パラメータを指定することができます。 Oracleサーバ < 9.2 を使用している場合、このパラメータは無視され、 かわりに環境変数 NLS_LANG が使用されます。

例 1. oci_connect() の例

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

$c1 = oci_connect("scott", "tiger", $db);
$c2 = oci_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);  // c1 を使って行を挿入
insert_data($c2);  // c2 を使って行を挿入

select_data($c1);  // 両方の挿入した結果が返される
select_data($c2);

rollback($c1);      // c1 を使ってロールバック

select_data($c1);  // どちらの挿入もロールバックされている
select_data($c2);

insert_data($c2);  // c2 を使って行を挿入
commit($c2);        // c2 を使ってコミット

select_data($c1);  // c2 の結果が返される

delete_data($c1);  // c1 を使ってテーブル内の全ての行を削除
select_data($c1);  // 行は返されない
select_data($c2);  // 行は返されない
commit($c1);        // c1 を使ってコミット

select_data($c1);  // 行は返されない
select_data($c2);  // 行は返されない

drop_table($c1);
echo
"</pre>";
?>

エラーの場合、oci_connect()FALSE を返します。

注意: PHP バージョン 5.0.0 以前では、代わりに ocilogon() を使用しなければなりません。 まだこの名前を使用することができ、下位互換性のため oci_connect() への別名として残されていますが、 推奨されません。

oci_pconnect(), oci_new_connect(), oci_close() も参照ください。



add a note add a note User Contributed Notes
oci_connect
greatval <wow> gmail <dot> com
25-Jul-2006 01:30
For use PHPv5 functions in PHPv4 i use simple script:
<?php
$funcs
=array(
      
'oci_connect'=>'OCILogon',
      
'oci_parse'=>'OCIParse',
      
'oci_execute'=>'OCIExecute',
      
'oci_fetch'=>'OCIFetch',
      
'oci_num_fields'=>'OCINumCols',
      
'oci_field_name'=>'OCIColumnName',
      
'oci_result'=>'OCIResult',
      
'oci_free_statement'=>'OCIFreeStatement',
);
// yoy can add yours pairs of funcs.

foreach ($funcs as $k=>$v)
   {
       if (!
function_exists($k))
           {
              
$arg_string='$p0';
               for (
$i=1;$i<20;$i++) {
                  
$arg_string.=',$p'.$i;
               }
               eval (
'function '.$k.' () {
                       list('
.$arg_string.')=func_get_args();
                       return '
.$v.'('.$arg_string.');
                       }
               '
);
           }
   }
?>

simple, but it work. :-)
Andrei
07-Nov-2005 10:08
lost oracle connection. need restart apache?

Temporarely you can prevent 'connection lost' by using folowing script (use it at your own risk):

<?php
$rnum
=rand(0,99999999);
$dbcon = oci_new_connect('XXXXX', 'XXXXXX',
'
(DESCRIPTION =
           (ADDRESS =
       (PROTOCOL = TCP)
       (HOST = XXX.XXX.XXX.XXX)
       (PORT = 1521)
       (HASH = '
.$rnum.')
     )
         (CONNECT_DATA =(SID = XXX))
     )
'
);
?>
Domenico a01b20_NOSPAM_ at iol dot it
07-Nov-2005 05:44
This note is an addendum to note#58378
Seems to be a good workaround set the oracle_home and/instead of the tns_admin.
tnsnames.ora must to be located in
$ORACLE_HOME/network/admin
and in
$TNS_ADMIN/ (if you use it)

---
Best Regards,
Domenico
a01b02_NO_SPAM at iol dot it
02-Nov-2005 07:44
Using tnsnames.ora
Apache 2
php 5.0.5
Oracle 10 IstantClient

PHP half of times return this error:

OCISessionBegin: ORA-24327: need explicit attach before authenticating a user in ...

In Oracle manual I find:

ORA-24327 need explicit attach before authenticating a user

   Cause: A server context must be initialized before creating a session.
   Action: Create and initialize a server handle.

I resolved using Easy Connect Naming Method.

Notice of this problem in bug#29779.

---
Best Regards,
Domenico
Chris
28-Oct-2005 09:19
Our tnsnames.ora uses the SERVICE_NAME=mydb - which for some reason wont work with PHP even though it works fine with tnsping. Using SID=mydb worked and a connection was established.

<oci_commitoci_define_by_name" width="11" height="7"/>
 Last updated: Sun, 07 May 2006
show source | credits | sitemap | contact | advertising | mirror sites 
Copyright © 2001-2006 The PHP Group
All rights reserved.
This mirror generously provided by: PacketBusiness, Inc.
Last updated: Mon Sep 4 03:27:26 2006 JST