ID:               9496
 Updated by:       [EMAIL PROTECTED]
 Reported By:      [EMAIL PROTECTED]
-Status:           Open
+Status:           Closed
 Bug Type:         OCI8 related
 Operating System: linux red hat 6.2
 PHP Version:      4.0.4pl1
 New Comment:

i still cannot see any problem. you approach would consume _more_
resourcs on the oracle server. anyhow this is not a bug.



Previous Comments:
------------------------------------------------------------------------

[2001-06-15 03:53:55] [EMAIL PROTECTED]


I think this behaviour is confusing.

One can have the needs to mix persistant and non persistant connexion
on the same database. In my case, I want to validate an account with a
personal username and after use a generic account. The first one must
not be persistant because we would have too much connexions open.



------------------------------------------------------------------------

[2001-05-04 10:44:07] [EMAIL PROTECTED]

OCIPlogon() will do the same as OCILogon() but mark the sever and
session handle as persistent, which means that PHP won't close them on
script-end. if your script does a OCILogon("s","t") and later a
OCIPLogon("s","t") _no_ new server or session handle will be created
but instead the existing ones will be marked persistent.

this is intended behaviour - why would we want to change it?


------------------------------------------------------------------------

[2001-02-28 08:33:16] [EMAIL PROTECTED]

With the following test (test_oci8.php) both connexions (USER_1 and
USER_2) are persistant.

Notes :

1. We can see that connexions are persistant with the following SQL
command :

  select username, status, logon_time from v$session where
username='USER_1' or username='USER_2';
  
2. We can use the following workaround : use a different database name
for USER_1 and USER_2 (who acces the same real database).

3. If we invert the order of connexions (USER_2 before USER_1) and use
OCInlogon for USER_1, only USER_2 has persistant connexions but the
number of connexions of USER_2 increase until to reach the maximum
limit (ORA-00604 error).


-------------------------------
test_oci8.php
-------------------------------
<html>
<title>OCI8 bug test</title>
</head>
<body>
<%

    $user = "USER_1";
    $password = "pwd1";
    $database = "TEST";

    {
        // should be non persistent !!!!
        $connexion = OCIlogon (
            $user,
            $password,
            $database);

        if (!$connexion)
        {
            trigger_error (
                "Erreur OCIlogon $user / $database",
                E_USER_ERROR);
        }
        else
        {
            echo "<p>Connexion 1 OK";
        }

        OCIlogoff ($connexion);
    }
    
    {
        $user = "USER_2";
        $password = "pwd2";
        $database = "TEST";

        // If we use a different databasename (for the same real
database) we don't have the problem
        // $database = "TEST2";

        $connexion = OCIplogon (
            $user,
            $password,
            $database);

        if (!$connexion)
        {
            trigger_error (
                "Erreur OCIplogon $user / $database",
                E_USER_ERROR);
        }
        else
        {
            echo "<p>Connexion 2 OK";
        }

        OCIlogoff ($connexion);
    }
    

%>
</body>
</html>
-------------------------------



------------------------------------------------------------------------


-- 
Edit this bug report at http://bugs.php.net/?id=9496&edit=1

Reply via email to