Connecting To an Oracle DB with PHP

Hello,

I'm trying to connect to a oracle database using PHP.  I have already enable the extension OCI8 and tried to connect. However when I try to connect I get the error message:


Fatal error: Call to undefined function oci_connect() in C:\wamp\www\test\connection2.php on line 15

Below is the code I'm using to connect. For some reason, i think Its not recognizing the OCI. If anyone see anything wrong with my code please let me know thanks.
$c = oci_connect("username","password","localhost/xe");

Open in new window

Robert ThomasProgram Analyst / Web DeveloperAsked:
Who is Participating?
I wear a lot of hats...

"The solutions and answers provided on Experts Exchange have been extremely helpful to me over the last few years. I wear a lot of hats - Developer, Database Administrator, Help Desk, etc., so I know a lot of things but not a lot about one thing. Experts Exchange gives me answers from people who do know a lot about one thing, in a easy to use platform." -Todd S.

Sander StadSysteemontwikkelaar, Database AdministratorCommented:
Are you sure you enabled the Oracle extension. Can you try do get the results from phpinfo() from your server?

To do this:
- Create a new php file
- Put in the code below
- Open the php file through your webserver in a brwoser



<?php
 
phpinfo();
 
?>

Open in new window

0
Sander StadSysteemontwikkelaar, Database AdministratorCommented:
If it is enabled you should get something like:

OCI8 Support => enabled
 Version => 1.2.4
 Revision => $Revision: 1.269.2.16.2.38 $
 Active Persistent Connections => 0
 Active Connections => 0
 Oracle Version => 10.1
 Compile-time ORACLE_HOME => /ORACLE/app/oracle/product/client
 Libraries Used =>
 Temporary Lob support => enabled
 Collections support => enabled

If it's not enabled you should check if you've edited the right php.ini file.

If everything is ok try the code below to create a testpage to see if the connection succeeds.
I see that you're using "localhost/xe" in your connection. Try to use the local ip address "127.0.0.1" to connect. Windows might create problem by using the value "localhost".

<?php
if ($conn = oci_connect('hr', 'hr', '//127.0.0.1:1521/xe')) {
  print 'Successfully connected to Oracle Database XE!';
  oci_close($conn);
} else {
  $errmsg = oci_error();
  print 'Oracle connect error: ' . $errmsg;
}
?>

Open in new window

0
Robert ThomasProgram Analyst / Web DeveloperAuthor Commented:
I think I properly enable oci8. But its not showing on the information page. I went into the php.ini file and enable it in the the extension area by taking away the ";".  But I just found the OCI8 section below. Probably a stupid question, but do I need to un-comment and enable all the scripts in that section?
0
Microsoft Azure 2017

Azure has a changed a lot since it was originally introduce by adding new services and features. Do you know everything you need to about Azure? This course will teach you about the Azure App Service, monitoring and application insights, DevOps, and Team Services.

Sander StadSysteemontwikkelaar, Database AdministratorCommented:
If the extension is not showing on the info page than you did not enable it. You probably have multiple php.ini  files.
Can you search your server/computer for the php.ini files.

If you want to set different settings like max connection etc then you can enable th settints in the OCI8 section.
0
Robert ThomasProgram Analyst / Web DeveloperAuthor Commented:
I've checked there appears to be only one.  The only place oci8 appears in the php info in the configure command:

cscript /nologo configure.js "--enable-snapshot-build" "--enable-debug-pack" "--with-pdo-oci=C:\php-sdk\oracle\instantclient10\sdk,shared" "--with-oci8=C:\php-sdk\oracle\instantclient10\sdk,shared"

Is there any possible way that the extension could be blocked by another extention?
0
Robert ThomasProgram Analyst / Web DeveloperAuthor Commented:
I had to edit the the system path and install the system client before the oci8 extension could be used.
0

Experts Exchange Solution brought to you by

Your issues matter to us.

Facing a tech roadblock? Get the help and guidance you need from experienced professionals who care. Ask your question anytime, anywhere, with no hassle.

Start your 7-day free trial
It's more than this solution.Get answers and train to solve all your tech problems - anytime, anywhere.Try it for free Edge Out The Competitionfor your dream job with proven skills and certifications.Get started today Stand Outas the employee with proven skills.Start learning today for free Move Your Career Forwardwith certification training in the latest technologies.Start your trial today
PHP

From novice to tech pro — start learning today.