|
 |
oci_connect (PHP 5) oci_connect -- Устанавливает соединение с сервером Oracle Описаниеresource oci_connect ( string username, string password [, string db [, string charset]] )
oci_connect() возвращает идентификатор
соединения, который используется большинством функций данного модуля.
Необязательный третий параметр может содержать имя локального экземпляра
Oracle или имя одной из записей в файле tnsnames.ora.
Если третий параметр не указан, PHP использует переменные окружения
ORACLE_SID и TWO_TASK, которые
используются для определения имени локального экземпляра Oracle и
местонахождения файла tnsnames.ora соответственно.
Замечание:
oci_connect() не устанавливает
соединение повторно, если соединение с такими параметрами (логин, пароль,
имя сервера) уже было установлено. Вместо этого,
oci_connect() вернет идентификатор уже открытого
соединения. Это означает, что вам не следует использовать
oci_connect() для разделения нескольких транзакций.
Если вы уверены, что хотите установить соединение с теми же параметрами
заново, то вам следует использовать 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); insert_data($c2); 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>";
?>
|
|
В случае ошибки oci_connect() возвращает FALSE.
Замечание:
В версиях PHP ниже 5.0.0 эта функция называлась ocilogon().
В PHP 5.0.0 и выше ocilogon() является
алиасом oci_connect(), поэтому вы можете
продолжать использовать это имя, однако это не рекомендуется.
См. также oci_pconnect() и
oci_new_connect().
oci_connect
Andrei
07-Nov-2005 05: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 12: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 02: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
27-Oct-2005 05: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.
| |