|  Download PDOCI| :warning: WARNING This software is abandonware. As the creator and maintainer, I don't even use PHP or Oracle _for years_, so, I can't support it anymore. It should work ok for PHP untill version 7, but seems that with 8.1 there are some alerts. Feel free to fork it and keep it going. |
| --- | Wrapping on PHP OCI functions to simulate a PDO object, using just pure PHP and the oci_* functions. Let's face it. Installing PHP, PDO, Oracle drivers and PDO OCI is not a pleasant
task. Is more pleasant to insert bamboo sticks under your fingernails than make
all the voodoo needed to accomplish that task. And there are two big problems
with that: 
If you install `pdo_oci` with `pecl` you'll get a version from 2005 (http://pecl.php.net/package/PDO_OCI). 
Even Christian Bale is now far from the things from 2005, and wow, he had a
cool suit and a very nice car.
And all came in black.
If you follow the official docs, you'll need to compile PHP and still get an
experimental extension (http://www.php.net/manual/ref.pdo-oci.php). Come on. 
We can't (yeah, we know how to do it!) compile PHP on every server we need
and just for an experimental feature?
 That's why I made PDOOCI. InstallationFirst install the Oracle drivers (I like the instant client versions) and the
oci8package (withpecl, this one seems to be updated often). With Composer$ composer require taq/pdooci
 {
    "require": {
        "taq/pdooci": "^1.0"
    }
}
 <?php
require_once 'vendor/autoload.php';
$pdo = new PDOOCI\PDO("mydatabase", "user", "password");
 Without ComposerWhy are you not using composer? Download the srcfolder from the repo and rename it toPDOOCI, then require thePDOOCI/PDO.phpfile. require_once "PDOOCI/PDO.php";
$pdo = new PDOOCI\PDO("mydatabase", "user", "password");
 Yeah, the rest should work exactly the same as if you were using a PDO object. :-) TestingThere is a test suite (using PHPUnitwith a version bigger than 6.x) on thetestdirectory. If you want to test (you must test your code!), create a table
calledpeoplewith two columns: 
`name` as `varchar2(50)`
`email` as `varchar2(30)` 
 And some environment variables: 
`PDOOCI_user` with the database user name
`PDOOCI_pwd` with the database password
`PDOOCI_str` with the database connection string
 Don't forget to run composer install! And then go to the testdir and runPHPUnitlike: phpunit --colors .
 |