Make WordPress Core

Ticket #21663: 21663.6.patch

File 21663.6.patch, 19.9 KB (added by scribu, 12 years ago)

get_driver() -> set_driver() + cleanup

  • new file wp-includes/class-wp-db-driver-mysql.php

    diff --git wp-includes/class-wp-db-driver-mysql.php wp-includes/class-wp-db-driver-mysql.php
    new file mode 100644
    index 0000000..237a3b5
    - +  
     1<?php
     2
     3/**
     4 * Database driver, using the mysql extension.
     5 *
     6 * @link http://php.net/manual/en/book.mysqli.php
     7 *
     8 * @package WordPress
     9 * @subpackage Database
     10 * @since 3.6.0
     11 */
     12class wpdb_driver_mysql implements wpdb_driver {
     13
     14        /**
     15         * Database link
     16         * @var resource
     17         */
     18        private $dbh = null;
     19
     20        /**
     21         * Result set
     22         * @var resource
     23         */
     24        private $result = null;
     25
     26        /**
     27         * Cached column info
     28         * @var array|null
     29         */
     30        private $col_info = null;
     31
     32        /**
     33         * Escape with mysql_real_escape_string()
     34         * @param  string $string
     35         * @return string
     36         */
     37        public function escape( $string ) {
     38                return mysql_real_escape_string( $string, $this->dbh );
     39        }
     40
     41        /**
     42         * Get the latest error message from the DB driver
     43         * @return string
     44         */
     45        public function get_error_message() {
     46                return mysql_error( $this->dbh );
     47        }
     48
     49        /**
     50         * Free memory associated with the resultset
     51         * @return void
     52         */
     53        public function flush() {
     54                if ( is_resource( $this->result ) ) {
     55                        mysql_free_result( $this->result );
     56                }
     57                $this->result = null;
     58                $this->col_info = null;
     59        }
     60
     61        /**
     62         * Connect to database
     63         * @return bool
     64         */
     65        public function connect( $host, $user, $pass, $port = 3306 ) {
     66
     67                $new_link = defined( 'MYSQL_NEW_LINK' ) ? MYSQL_NEW_LINK : true;
     68                $client_flags = defined( 'MYSQL_CLIENT_FLAGS' ) ? MYSQL_CLIENT_FLAGS : 0;
     69
     70                if ( WP_DEBUG ) {
     71                        $this->dbh =  mysql_connect( "$host:$port", $user, $pass, $new_link, $client_flags );
     72                } else {
     73                        $this->dbh = @mysql_connect( "$host:$port", $user, $pass, $new_link, $client_flags );
     74                }
     75                return ( false !== $this->dbh );
     76        }
     77
     78        /**
     79         * Select database
     80         * @return void
     81         */
     82        public function select( $db ) {
     83                if ( WP_DEBUG ) {
     84                         mysql_select_db( $db, $this->dbh );
     85                } else {
     86                        @mysql_select_db( $db, $this->dbh );
     87                }
     88        }
     89
     90        /**
     91         * Perform a MySQL database query, using current database connection.
     92         * @param string $query Database query
     93         * @return int|false Number of rows affected/selected or false on error
     94         */
     95        public function query( $query ) {
     96                $this->result = @mysql_query( $query, $this->dbh );
     97                if ( preg_match( '/^\s*(create|alter|truncate|drop)\s/i', $query ) ) {
     98                        $return_val = $this->result;
     99                } elseif ( preg_match( '/^\s*(insert|delete|update|replace)\s/i', $query ) ) {
     100                        $return_val = $this->affected_rows();
     101                } elseif ( preg_match( '/^\s*select\s/i', $query ) ) {
     102                        return is_resource( $this->result ) ? mysql_num_rows( $this->result ) : false ;
     103                }
     104                return true;
     105        }
     106
     107        /**
     108         * Get number of rows affected
     109         * @return int
     110         */
     111        public function affected_rows() {
     112                return mysql_affected_rows( $this->dbh );
     113        }
     114
     115        /**
     116         * Get last insert id
     117         * @return int
     118         */
     119        public function insert_id() {
     120                return mysql_insert_id( $this->dbh );
     121        }
     122
     123        /**
     124         * Get results
     125         * @return array
     126         */
     127        public function get_results() {
     128                $ret = array();
     129                while ( $row = @mysql_fetch_object( $this->result ) ) {
     130                        $ret[] = $row;
     131                }
     132                return $ret;
     133        }
     134
     135        /**
     136         * Load the column metadata from the last query.
     137         * @return array
     138         */
     139        public function load_col_info() {
     140                if ( $this->col_info )
     141                        return $this->col_info;
     142                for ( $i = 0; $i < @mysql_num_fields( $this->result ); $i++ ) {
     143                        $this->col_info[ $i ] = @mysql_fetch_field( $this->result, $i );
     144                }
     145                return $this->col_info;
     146        }
     147
     148        /**
     149         * The database version number.
     150         * @return false|string false on failure, version number on success
     151         */
     152        public function db_version() {
     153                return preg_replace( '/[^0-9.].*/', '', mysql_get_server_info( $this->dbh ) );
     154        }
     155}
  • new file wp-includes/class-wp-db-driver-mysqli.php

    diff --git wp-includes/class-wp-db-driver-mysqli.php wp-includes/class-wp-db-driver-mysqli.php
    new file mode 100644
    index 0000000..fd3f681
    - +  
     1<?php
     2
     3/**
     4 * Database driver, using the mysqli extension.
     5 *
     6 * @link http://php.net/manual/en/book.mysqli.php
     7 *
     8 * @package WordPress
     9 * @subpackage Database
     10 * @since 3.6.0
     11 */
     12class wpdb_driver_mysqli implements wpdb_driver {
     13
     14        /**
     15         * Database link
     16         * @var mysqli
     17         */
     18        private $dbh = null;
     19
     20        /**
     21         * Result set
     22         * @var mysqli_stmt|mysqli_result
     23         */
     24        private $result = null;
     25
     26        /**
     27         * Cached column info
     28         * @var array|null
     29         */
     30        private $col_info = null;
     31
     32        /**
     33         * Escape with mysql_real_escape_string()
     34         * @param  string $string
     35         * @return string
     36         */
     37        public function escape( $string ) {
     38                return $this->dbh->escape_string( $string );
     39        }
     40
     41        /**
     42         * Get the latest error message from the DB driver
     43         * @return string
     44         */
     45        public function get_error_message() {
     46                return $this->dbh->error;
     47        }
     48
     49        /**
     50         * Free memory associated with the resultset
     51         * @return void
     52         */
     53        public function flush() {
     54                if ( $this->result instanceof mysqli_stmt ) {
     55                        $this->result->free_result();
     56                }
     57                $this->result = null;
     58                $this->col_info = null;
     59        }
     60
     61        /**
     62         * Connect to database
     63         * @return bool
     64         */
     65        public function connect( $host, $user, $pass, $port = 3306 ) {
     66                $this->dbh = new mysqli( $host, $user, $pass, '', $port );
     67                return ( !mysqli_connect_error() );
     68        }
     69
     70        /**
     71         * Select database
     72         * @return void
     73         */
     74        public function select( $db ) {
     75                $this->dbh->select_db( $db );
     76        }
     77
     78        /**
     79         * Perform a MySQL database query, using current database connection.
     80         * @param string $query Database query
     81         * @return int|false Number of rows affected/selected or false on error
     82         */
     83        public function query( $query ) {
     84                $this->result = $this->dbh->query( $query );
     85                if ( preg_match( '/^\s*(create|alter|truncate|drop)\s/i', $query ) ) {
     86                        $return_val = $this->result;
     87                } elseif ( preg_match( '/^\s*(insert|delete|update|replace)\s/i', $query ) ) {
     88                        $return_val = $this->affected_rows();
     89                } elseif ( preg_match( '/^\s*select\s/i', $query ) ) {
     90                        return $this->result->num_rows;
     91                }
     92                return true;
     93        }
     94
     95        /**
     96         * Get number of rows affected
     97         * @return int
     98         */
     99        public function affected_rows() {
     100                return $this->dbh->affected_rows;
     101        }
     102
     103        /**
     104         * Get last insert id
     105         * @return int
     106         */
     107        public function insert_id() {
     108                return $this->dbh->insert_id;
     109        }
     110
     111        /**
     112         * Get results
     113         * @return array
     114         */
     115        public function get_results() {
     116                $ret = array();
     117                while ( $row = $this->result->fetch_object() ) {
     118                        $ret[] = $row;
     119                }
     120                return $ret;
     121        }
     122
     123        /**
     124         * Load the column metadata from the last query.
     125         * @return array
     126         */
     127        public function load_col_info() {
     128                if ( $this->col_info )
     129                        return $this->col_info;
     130                for ( $i = 0; $i < $this->result->field_count ; $i++ ) {
     131                        $this->col_info[ $i ] = $this->result->fetch_field_direct( $i );
     132                }
     133                return $this->col_info;
     134        }
     135
     136        /**
     137         * The database version number.
     138         * @return false|string false on failure, version number on success
     139         */
     140        public function db_version() {
     141                return preg_replace( '/[^0-9.].*/', '', $this->dbh->server_version );
     142        }
     143}
  • new file wp-includes/class-wp-db-driver-pdo_mysql.php

    diff --git wp-includes/class-wp-db-driver-pdo_mysql.php wp-includes/class-wp-db-driver-pdo_mysql.php
    new file mode 100644
    index 0000000..6a2c47f
    - +  
     1<?php
     2
     3/**
     4 * Database driver, using the PDO extension.
     5 *
     6 * @link http://php.net/manual/en/book.pdo.php
     7 *
     8 * @package WordPress
     9 * @subpackage Database
     10 * @since 3.6.0
     11 */
     12class wpdb_driver_pdo_mysql implements wpdb_driver {
     13
     14        /**
     15         * Database link
     16         * @var PDO
     17         */
     18        private $dbh = null;
     19
     20        /**
     21         * Result set
     22         * @var PDOStatement
     23         */
     24        private $result = null;
     25
     26        /**
     27         * Cached column info
     28         * @var array|null
     29         */
     30        private $col_info = null;
     31
     32        /**
     33         * Array of fetched rows.
     34         * PDO doesn't have a "count rows" feature, so we have to fetch the rows
     35         * up front, and cache them here
     36         * @var array
     37         */
     38        private $fetched_rows = array();
     39
     40        /**
     41         * Escape with mysql_real_escape_string()
     42         * @param  string $string
     43         * @return string
     44         */
     45        public function escape( $string ) {
     46                return substr( $this->dbh->quote( $string ), 1, -1 );
     47        }
     48
     49        /**
     50         * Get the latest error message from the DB driver
     51         * @return string
     52         */
     53        public function get_error_message() {
     54                $error = $this->dbh->errorInfo();
     55                if ( isset( $error[2] ) ) {
     56                        return $error[2];
     57                }
     58                return '';
     59        }
     60
     61        /**
     62         * Free memory associated with the resultset
     63         * @return void
     64         */
     65        public function flush() {
     66                if ( $this->result instanceof PDOStatement ) {
     67                        $this->result->closeCursor();
     68                }
     69                $this->result = null;
     70                $this->col_info = null;
     71                $this->fetched_rows = array();
     72        }
     73
     74        /**
     75         * Connect to database
     76         * @return bool
     77         */
     78        public function connect( $host, $user, $pass, $port = 3306 ) {
     79                $dsn = sprintf( 'mysql:host=%1$s;port=%2$d', $host, $port );
     80                try {
     81                        $this->dbh = new PDO( $dsn, $user, $pass );
     82                } catch ( Exception $e ) {
     83                        return false;
     84                }
     85                return true;
     86        }
     87
     88        /**
     89         * Select database
     90         * @return void
     91         */
     92        public function select( $db ) {
     93                $this->dbh->exec( sprintf( 'USE %s', $db ) );
     94        }
     95
     96        /**
     97         * Perform a MySQL database query, using current database connection.
     98         * @param string $query Database query
     99         * @return int|false Number of rows affected/selected or false on error
     100         */
     101        public function query( $query ) {
     102                try {
     103                        $this->result = $this->dbh->query( $query );
     104                } catch ( Exception $e ) {
     105                }
     106                if ( preg_match( '/^\s*(create|alter|truncate|drop)\s/i', $query ) ) {
     107                        $return_val = $this->result;
     108                } elseif ( preg_match( '/^\s*(insert|delete|update|replace)\s/i', $query ) ) {
     109                        $return_val = $this->affected_rows();
     110                } elseif ( preg_match( '/^\s*select\s/i', $query ) ) {
     111                        $this->get_results();
     112                        return count( $this->fetched_rows );
     113                }
     114                return true;
     115        }
     116
     117        /**
     118         * Get number of rows affected
     119         * @return int
     120         */
     121        public function affected_rows() {
     122                if ( $this->result instanceof PDOStatement ) {
     123                        return $this->result->rowCount();
     124                }
     125                return 0;
     126        }
     127
     128        /**
     129         * Get last insert id
     130         * @return int
     131         */
     132        public function insert_id() {
     133                return $this->dbh->lastInsertId();
     134        }
     135
     136        /**
     137         * Get results
     138         * @return array
     139         */
     140        public function get_results() {
     141                if ( !empty( $this->fetched_rows ) ) {
     142                        return $this->fetched_rows;
     143                }
     144                $this->fetched_rows = array();
     145                if ( !empty( $this->result ) ) {
     146                        while ( $row = $this->result->fetchObject() ) {
     147                                $this->fetched_rows[] = $row;
     148                        }
     149                }
     150                return $this->fetched_rows;
     151        }
     152
     153        /**
     154         * Load the column metadata from the last query.
     155         * @return array
     156         */
     157        public function load_col_info() {
     158                if ( $this->col_info )
     159                        return $this->col_info;
     160                for ( $i = 0; $i < $this->result->columnCount() ; $i++ ) {
     161                        $this->col_info[ $i ] = $this->result->fetchColumn( $i );
     162                }
     163                return $this->col_info;
     164        }
     165
     166        /**
     167         * The database version number.
     168         * @return false|string false on failure, version number on success
     169         */
     170        public function db_version() {
     171                return preg_replace( '/[^0-9.].*/', '', $this->dbh->getAttribute( PDO::ATTR_SERVER_VERSION ) );
     172        }
     173}
  • new file wp-includes/interface-wp-db-driver.php

    diff --git wp-includes/interface-wp-db-driver.php wp-includes/interface-wp-db-driver.php
    new file mode 100644
    index 0000000..8bb421a
    - +  
     1<?php
     2
     3interface wpdb_driver {
     4        public function escape( $string );
     5        public function get_error_message();
     6        public function flush();
     7        public function connect( $host, $user, $pass, $port = 3306 );
     8        public function select( $name );
     9        public function query( $query );
     10        public function load_col_info();
     11        public function db_version();
     12        public function affected_rows();
     13        public function insert_id();
     14        public function get_results();
     15}
  • wp-includes/load.php

    diff --git wp-includes/load.php wp-includes/load.php
    index 1742af4..16e8b5e 100644
    function wp_set_lang_dir() { 
    326326function require_wp_db() {
    327327        global $wpdb;
    328328
     329        require( ABSPATH . WPINC . '/interface-wp-db-driver.php' );
    329330        require_once( ABSPATH . WPINC . '/wp-db.php' );
    330331        if ( file_exists( WP_CONTENT_DIR . '/db.php' ) )
    331332                require_once( WP_CONTENT_DIR . '/db.php' );
  • wp-includes/wp-db.php

    diff --git wp-includes/wp-db.php wp-includes/wp-db.php
    index 391cfa4..de17d7b 100644
    class wpdb { 
    487487        protected $dbhost;
    488488
    489489        /**
    490          * Database Handle
     490         * Database driver object
     491         *
     492         * Allow for simple, and backwards compatible, pluggable database drivers
     493         * like PDO_mysql and mysqli to power wpdb
    491494         *
    492          * @since 0.71
    493495         * @access protected
    494          * @var string
     496         * @since 3.5.0
     497         * @var wpdb_driver
    495498         */
    496499        protected $dbh;
    497500
    class wpdb { 
    519522        public $is_mysql = null;
    520523
    521524        /**
     525         * Pick the adapter to be used for performing the actual queries.
     526         *
     527         * @since 3.6.0
     528         */
     529        private function set_driver() {
     530
     531                // Auto-pick the driver
     532                if ( defined( 'WPDB_DRIVER' ) ) {
     533                        $driver = WPDB_DRIVER;
     534                } elseif ( extension_loaded( 'pdo_mysql' ) ) {
     535                        $driver = 'pdo_mysql';
     536                } elseif ( extension_loaded( 'mysqli' ) ) {
     537                        $driver = 'mysqli';
     538                } elseif ( extension_loaded( 'mysql' ) ) {
     539                        $driver = 'mysql';
     540                }
     541
     542                // Get the new driver
     543                if ( in_array( $driver, array( 'mysql', 'mysqli', 'pdo_mysql' ) ) ) {
     544                        require_once( ABSPATH . WPINC . '/class-wp-db-driver-' . $driver . '.php' );
     545                }
     546                $class = 'wpdb_driver_' . $driver;
     547
     548                if ( !class_exists( $class ) ) {
     549                        wp_load_translations_early();
     550                        $this->bail( sprintf( __( "
     551                                <h1>No database drivers found</h1>.
     552                                <p>WordPress requires the mysql, mysqli, or pdo_mysql extension to talk to your database.</p>
     553                                <p>If you're unsure what these terms mean you should probably contact your host. If you still need help you can always visit the <a href='http://wordpress.org/support/'>WordPress Support Forums</a>.</p>
     554                        "), 'db_connect_fail' ) );
     555                }
     556
     557                $this->dbh = new $class();
     558        }
     559
     560        /**
    522561         * Connects to the database server and selects a database
    523562         *
    524563         * PHP5 style constructor for compatibility with PHP5. Does
    class wpdb { 
    534573         * @param string $dbhost MySQL database host
    535574         */
    536575        function __construct( $dbuser, $dbpassword, $dbname, $dbhost ) {
     576                $this->set_driver();
     577
    537578                register_shutdown_function( array( $this, '__destruct' ) );
    538579
    539580                if ( WP_DEBUG )
    class wpdb { 
    646687                if ( !isset($collate) )
    647688                        $collate = $this->collate;
    648689                if ( $this->has_cap( 'collation', $dbh ) && !empty( $charset ) ) {
    649                         if ( function_exists( 'mysql_set_charset' ) && $this->has_cap( 'set_charset', $dbh ) ) {
    650                                 mysql_set_charset( $charset, $dbh );
    651                                 $this->real_escape = true;
    652                         } else {
    653                                 $query = $this->prepare( 'SET NAMES %s', $charset );
    654                                 if ( ! empty( $collate ) )
    655                                         $query .= $this->prepare( ' COLLATE %s', $collate );
    656                                 mysql_query( $query, $dbh );
    657                         }
     690                        $query = $this->prepare( 'SET NAMES %s', $charset );
     691                        if ( ! empty( $collate ) )
     692                                $query .= $this->prepare( ' COLLATE %s', $collate );
     693                        $this->dbh->query( $query );
    658694                }
    659695        }
    660696
    class wpdb { 
    837873         * @return null Always null.
    838874         */
    839875        function select( $db, $dbh = null ) {
    840                 if ( is_null($dbh) )
    841                         $dbh = $this->dbh;
    842 
    843                 if ( !@mysql_select_db( $db, $dbh ) ) {
    844                         $this->ready = false;
    845                         wp_load_translations_early();
    846                         $this->bail( sprintf( __( '<h1>Can&#8217;t select database</h1>
    847 <p>We were able to connect to the database server (which means your username and password is okay) but not able to select the <code>%1$s</code> database.</p>
    848 <ul>
    849 <li>Are you sure it exists?</li>
    850 <li>Does the user <code>%2$s</code> have permission to use the <code>%1$s</code> database?</li>
    851 <li>On some systems the name of your database is prefixed with your username, so it would be like <code>username_%1$s</code>. Could that be the problem?</li>
    852 </ul>
    853 <p>If you don\'t know how to set up a database you should <strong>contact your host</strong>. If all else fails you may find help at the <a href="http://wordpress.org/support/">WordPress Support Forums</a>.</p>' ), htmlspecialchars( $db, ENT_QUOTES ), htmlspecialchars( $this->dbuser, ENT_QUOTES ) ), 'db_select_fail' );
    854                         return;
    855                 }
     876                $this->dbh->select( $db );
    856877        }
    857878
    858879        /**
    class wpdb { 
    882903         */
    883904        function _real_escape( $string ) {
    884905                if ( $this->dbh && $this->real_escape )
    885                         return mysql_real_escape_string( $string, $this->dbh );
     906                        return $this->dbh->escape( $string );
    886907                else
    887908                        return addslashes( $string );
    888909        }
    class wpdb { 
    10171038                global $EZSQL_ERROR;
    10181039
    10191040                if ( !$str )
    1020                         $str = mysql_error( $this->dbh );
     1041                        $str = $this->dbh->get_error_message();
    10211042                $EZSQL_ERROR[] = array( 'query' => $this->last_query, 'error_str' => $str );
    10221043
    10231044                if ( $this->suppress_errors )
    class wpdb { 
    11141135         * @return void
    11151136         */
    11161137        function flush() {
    1117                 $this->last_result = array();
    1118                 $this->col_info    = null;
    1119                 $this->last_query  = null;
    1120 
    1121                 if ( is_resource( $this->result ) )
    1122                         mysql_free_result( $this->result );
     1138                $this->dbh->flush();
    11231139        }
    11241140
    11251141        /**
    class wpdb { 
    11311147
    11321148                $this->is_mysql = true;
    11331149
    1134                 $new_link = defined( 'MYSQL_NEW_LINK' ) ? MYSQL_NEW_LINK : true;
    1135                 $client_flags = defined( 'MYSQL_CLIENT_FLAGS' ) ? MYSQL_CLIENT_FLAGS : 0;
    1136 
    1137                 if ( WP_DEBUG ) {
    1138                         $this->dbh = mysql_connect( $this->dbhost, $this->dbuser, $this->dbpassword, $new_link, $client_flags );
    1139                 } else {
    1140                         $this->dbh = @mysql_connect( $this->dbhost, $this->dbuser, $this->dbpassword, $new_link, $client_flags );
     1150                $host = $this->dbhost;
     1151                $port = 3306;
     1152                if ( false !== strpos( $this->dbhost, ':' ) ) {
     1153                        list( $host, $port ) = explode( ':', $this->dbhost );
    11411154                }
    1142 
    1143                 if ( !$this->dbh ) {
     1155                if ( !$this->dbh->connect( $host, $this->dbuser, $this->dbpassword, $port ) ) {
    11441156                        wp_load_translations_early();
    11451157                        $this->bail( sprintf( __( "
    11461158<h1>Error establishing a database connection</h1>
    class wpdb { 
    11921204                if ( defined( 'SAVEQUERIES' ) && SAVEQUERIES )
    11931205                        $this->timer_start();
    11941206
    1195                 $this->result = @mysql_query( $query, $this->dbh );
     1207                $result = $this->dbh->query( $query );
    11961208                $this->num_queries++;
    11971209
    11981210                if ( defined( 'SAVEQUERIES' ) && SAVEQUERIES )
    11991211                        $this->queries[] = array( $query, $this->timer_stop(), $this->get_caller() );
    12001212
    12011213                // If there is an error then take note of it..
    1202                 if ( $this->last_error = mysql_error( $this->dbh ) ) {
     1214                if ( $this->last_error = $this->dbh->get_error_message() ) {
    12031215                        $this->print_error();
    12041216                        return false;
    12051217                }
    class wpdb { 
    12071219                if ( preg_match( '/^\s*(create|alter|truncate|drop)\s/i', $query ) ) {
    12081220                        $return_val = $this->result;
    12091221                } elseif ( preg_match( '/^\s*(insert|delete|update|replace)\s/i', $query ) ) {
    1210                         $this->rows_affected = mysql_affected_rows( $this->dbh );
     1222                        $this->rows_affected = $this->dbh->affected_rows();
    12111223                        // Take note of the insert_id
    12121224                        if ( preg_match( '/^\s*(insert|replace)\s/i', $query ) ) {
    1213                                 $this->insert_id = mysql_insert_id($this->dbh);
     1225                                $this->insert_id = $this->dbh->insert_id();
    12141226                        }
    12151227                        // Return number of rows affected
    12161228                        $return_val = $this->rows_affected;
    12171229                } else {
    1218                         $num_rows = 0;
    1219                         while ( $row = @mysql_fetch_object( $this->result ) ) {
    1220                                 $this->last_result[$num_rows] = $row;
    1221                                 $num_rows++;
    1222                         }
    1223 
    1224                         // Log number of rows the query returned
    1225                         // and return number of rows selected
    1226                         $this->num_rows = $num_rows;
    1227                         $return_val     = $num_rows;
     1230                        $return_val = $this->num_rows = count( $this->last_result );
    12281231                }
    12291232
     1233                $this->last_result = $this->dbh->get_results();
    12301234                return $return_val;
    12311235        }
    12321236
    class wpdb { 
    15561560         * @access protected
    15571561         */
    15581562        protected function load_col_info() {
    1559                 if ( $this->col_info )
    1560                         return;
    1561 
    1562                 for ( $i = 0; $i < @mysql_num_fields( $this->result ); $i++ ) {
    1563                         $this->col_info[ $i ] = @mysql_fetch_field( $this->result, $i );
    1564                 }
     1563                $this->col_info = $this->dbh->load_col_info();
    15651564        }
    15661565
    15671566        /**
    class wpdb { 
    17321731         * @return false|string false on failure, version number on success
    17331732         */
    17341733        function db_version() {
    1735                 return preg_replace( '/[^0-9.].*/', '', mysql_get_server_info( $this->dbh ) );
     1734                return $this->dbh->db_version();
    17361735        }
    17371736}