Skip to content
World Wide Web Server edited this page Jul 4, 2012 · 24 revisions

Category:Libraries::External | Category:Libraries::Database

[h3]Introduction[/h3] ([url=http://www.codeigniter.com/forums/viewthread/612/]Originally discussed here[/url]) Here's an [url=http://adodb.sourceforge.net/]ADOdb[/url] library for use in CI.

What are the benefits of Adodb? It's mature, and supports [url=http://phplens.com/adodb/supported.databases.html]lots of databases[/url]. I really like some of the features in it, [url=http://phplens.com/lens/adodb/docs-adodb.htm#autoexecute]autoexecute()[/url], and [url=http://phplens.com/lens/adodb/docs-adodb.htm#getrow]getrow()[/url] are particularly useful.

[h3]Setup[/h3]

  1. [url=http://sourceforge.net/project/showfiles.php?group_id=42718]Grab ADODB[/url]
  2. Unzip to system/application/libraries/adodb/
  3. Optionally apply ConfigLoadPatch (as of CI 1.3.3, this is not included), otherwise you'll have to create a valid config/adodb.php or you'll get a CI error (if you apply the patch, ADOdb will be able to detect that config/adodb.php doesn't exist and instead read your config/database.php file).
  4. Add the following source code to the appropriate directory

[h3]Source[/h3] [b]system/application/init/init_adodb.php[/b] [code]<?php if (!defined('BASEPATH')) exit('No direct script access allowed');

if (!function_exists('_init_adodb_library')) { function _init_adodb_library(&$ci) { $db_var = false; $debug = false;

    // try to load config/adodb.php
    // extra parameter comes from patch at http://www.codeigniter.com/wiki/ConfigLoadPatch/
    // without this patch, if config/adodb.php doesn't exist, CI will display a fatal error.
    if ($ci->config->load('adodb',true)) {
        $cfg = $ci->config->item('adodb');
        if (isset($cfg['dsn'])) {
            $dsn = $cfg['dsn'];
        }
        
        // set db_var if it's set in the config file, or false otherwise
        $db_var = isset($cfg['db_var']) && $cfg['db_var'];
        
        $debug = isset($cfg['debug']) && $cfg['debug'];
    } 
    
    if (!isset($dsn)) {
        // fallback to using the CI database file
        include(APPPATH.'config/database'.EXT);
        $group = 'default';
        $dsn = $db[$group]['dbdriver'].'://'.$db[$group]['username']
               .':'.$db[$group]['password'].'@'.$db[$group]['hostname']
               .'/'.$db[$group]['database'];
    }
    
    // $ci is by reference, refers back to global instance
    $ci->adodb =& ADONewConnection($dsn);
    
    if ($db_var) {
        // also set the normal CI db variable
        $ci->db =& $ci->adodb;
    }
    
    if ($debug) {
        $ci->adodb->debug = true;
    }
}

}

if ( ! class_exists('ADONewConnection') ) { require_once(APPPATH.'libraries/adodb/adodb.inc'.EXT); }

$obj =& get_instance(); _init_adodb_library($obj); $obj->ci_is_loaded[] = 'adodb';

?>[/code] [h3]Usage[/h3] By default, it will create an "adodb" object ($this->adodb) that is connected to the database defined in application/config/database.php (currently hardcoded to use the 'default' group). Alternatively, you can create an application/config/adodb.php file:

[code]<?php $config['adodb']['dsn'] = 'mysql://user:pass@localhost/dbname'; $config['adodb']['db_var'] = true; $config['adodb']['debug'] = false; ?>[/code]

All values are optional.

[b]dsn[/b] can be any valid DSN string, as described at [url=http://phplens.com/lens/adodb/docs-adodb.htm#connect_ex]http://phplens.com/lens/adodb/docs-adodb.htm#connect_ex[/url]. If not specified, the settings in config/database.php are used. [b]db_var[/b] if true will set $this->db to be a reference to $this->adodb, overwriting CodeIgniter's database object. Defaults to false. [b]debug[/b] sets ADOdb debug mode, defaults to false.

You can get going very fast: [code]$this->load->library('adodb'); $row = $this->adodb->getrow('SELECT * FROM users WHERE user_id = 1'); echo 'hello '.$row['firstname'];[/code]

You can also of course auto-load this like any other library, by adding it to the 'core' array in application/config/autoload.php:

[code]$autoload['core'] = array('adodb');[/code]

[h3]Notes[/h3] [h4]Patch Notice[/h4] Note that you need the patch described at this [url=http://www.codeigniter.com/forums/viewthread/611/]thread[/url] for the init to work, or alternatively, you can create a config/adodb.php file, or comment out the whole IF block where it mentions that patch url.

[h4]In the future..[/h4] Something that may be useful is to write wrappers for the ADOdb object that emulate all the functions in the CI database class, as well as the QueryResult class. Now, this adds abstraction to an abstraction layer.. so it may be unnecessarily complex, not to mention you kind of defeat the purpose of using ADOdb.

I have not yet played with the ADOdb [url=http://phplens.com/lens/adodb/docs-active-record.htm]active record[/url] stuff, but it may be possible to integrate it with models somehow.

Clone this wiki locally