WordPress.org

Make WordPress Core

Ticket #14672: 14672.2.diff

File 14672.2.diff, 8.2 KB (added by ryan, 8 years ago)

Drop WP_USE_MULTIPLE_DB

  • wp-includes/wp-db.php

     
    476476         * @param string $dbhost MySQL database host
    477477         */
    478478        function wpdb( $dbuser, $dbpassword, $dbname, $dbhost ) {
    479                 if( defined( 'WP_USE_MULTIPLE_DB' ) && WP_USE_MULTIPLE_DB )
    480                         $this->db_connect();
    481479                return $this->__construct( $dbuser, $dbpassword, $dbname, $dbhost );
    482480        }
    483481
     
    502500                if ( WP_DEBUG )
    503501                        $this->show_errors();
    504502
    505                 if ( is_multisite() ) {
     503                $this->init_charset();
     504
     505                $this->dbuser = $dbuser;
     506                $this->dbpassword = $dbpassword;
     507                $this->dbname = $dbname;
     508                $this->dbhost = $dbhost;
     509
     510                $this->db_connect();
     511        }
     512
     513        /**
     514         * PHP5 style destructor and will run when database object is destroyed.
     515         *
     516         * @see wpdb::__construct()
     517         * @since 2.0.8
     518         * @return bool true
     519         */
     520        function __destruct() {
     521                return true;
     522        }
     523
     524        /**
     525         * Set $this->charset and $this->collate
     526         */
     527        function init_charset() {
     528                if ( function_exists('is_multisite') && is_multisite() ) {
    506529                        $this->charset = 'utf8';
    507530                        if ( defined( 'DB_COLLATE' ) && DB_COLLATE )
    508531                                $this->collate = DB_COLLATE;
     
    514537
    515538                if ( defined( 'DB_CHARSET' ) )
    516539                        $this->charset = DB_CHARSET;
     540        }
    517541
    518                 $this->dbuser = $dbuser;
    519 
    520                 $this->dbh = @mysql_connect( $dbhost, $dbuser, $dbpassword, true );
    521                 if ( !$this->dbh ) {
    522                         $this->bail( sprintf( /*WP_I18N_DB_CONN_ERROR*/"
    523 <h1>Error establishing a database connection</h1>
    524 <p>This either means that the username and password information in your <code>wp-config.php</code> file is incorrect or we can't contact the database server at <code>%s</code>. This could mean your host's database server is down.</p>
    525 <ul>
    526         <li>Are you sure you have the correct username and password?</li>
    527         <li>Are you sure that you have typed the correct hostname?</li>
    528         <li>Are you sure that the database server is running?</li>
    529 </ul>
    530 <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>
    531 "/*/WP_I18N_DB_CONN_ERROR*/, $dbhost ), 'db_connect_fail' );
    532                         return;
    533                 }
    534 
    535                 $this->ready = true;
    536 
    537                 if ( $this->has_cap( 'collation' ) && !empty( $this->charset ) ) {
    538                         if ( function_exists( 'mysql_set_charset' ) ) {
    539                                 mysql_set_charset( $this->charset, $this->dbh );
     542        /**
     543         * Sets the connection's character set.
     544         *
     545         * @param resource $dbh     The resource given by mysql_connect
     546         * @param string   $charset The character set (optional)
     547         * @param string   $collate The collation (optional)
     548         */
     549        function set_charset($dbh, $charset = null, $collate = null) {
     550                if ( !isset($charset) )
     551                        $charset = $this->charset;
     552                if ( !isset($collate) )
     553                        $collate = $this->collate;
     554                if ( $this->has_cap( 'collation', $dbh ) && !empty( $charset ) ) {
     555                        if ( function_exists( 'mysql_set_charset' ) && $this->has_cap( 'set_charset', $dbh ) ) {
     556                                mysql_set_charset( $charset, $dbh );
    540557                                $this->real_escape = true;
    541558                        } else {
    542                                 $query = $this->prepare( 'SET NAMES %s', $this->charset );
    543                                 if ( ! empty( $this->collate ) )
    544                                         $query .= $this->prepare( ' COLLATE %s', $this->collate );
    545                                 $this->query( $query );
     559                                $query = $this->prepare( 'SET NAMES %s', $charset );
     560                                if ( ! empty( $collate ) )
     561                                        $query .= $this->prepare( ' COLLATE %s', $collate );
     562                                mysql_query( $query, $dbh );
    546563                        }
    547564                }
    548 
    549                 $this->select( $dbname, $this->dbh );
    550565        }
    551566
    552567        /**
    553          * PHP5 style destructor and will run when database object is destroyed.
    554          *
    555          * @see wpdb::__construct()
    556          * @since 2.0.8
    557          * @return bool true
    558          */
    559         function __destruct() {
    560                 return true;
    561         }
    562 
    563         /**
    564568         * Sets the table prefix for the WordPress tables.
    565569         *
    566570         * @since 2.5.0
     
    10171021                $this->last_query  = null;
    10181022        }
    10191023
    1020         function db_connect( $query = "SELECT" ) {
     1024        /**
     1025         * Connect to and select database
     1026         */
     1027        function db_connect() {
    10211028                global $db_list, $global_db_list;
    1022                 if ( ! is_array( $db_list ) )
    1023                         return true;
    10241029
    1025                 if ( $this->blogs != '' && preg_match("/(" . $this->blogs . "|" . $this->users . "|" . $this->usermeta . "|" . $this->site . "|" . $this->sitemeta . "|" . $this->sitecategories . ")/i",$query) ) {
    1026                         $action = 'global';
    1027                         $details = $global_db_list[ mt_rand( 0, count( $global_db_list ) -1 ) ];
    1028                         $this->db_global = $details;
    1029                 } elseif ( preg_match("/^\\s*(alter table|create|insert|delete|update|replace) /i",$query) ) {
    1030                         $action = 'write';
    1031                         $details = $db_list[ 'write' ][ mt_rand( 0, count( $db_list[ 'write' ] ) -1 ) ];
    1032                         $this->db_write = $details;
    1033                 } else {
    1034                         $action = '';
    1035                         $details = $db_list[ 'read' ][ mt_rand( 0, count( $db_list[ 'read' ] ) -1 ) ];
    1036                         $this->db_read = $details;
    1037                 }
     1030                $this->dbh = @mysql_connect( $this->dbhost, $this->dbuser, $this->dbpassword, true );
    10381031
    1039                 $dbhname = "dbh" . $action;
    1040                 $this->$dbhname = @mysql_connect( $details[ 'db_host' ], $details[ 'db_user' ], $details[ 'db_password' ] );
    1041                 if (!$this->$dbhname ) {
     1032                if ( !$this->dbh ) {
    10421033                        $this->bail( sprintf( /*WP_I18N_DB_CONN_ERROR*/"
    10431034<h1>Error establishing a database connection</h1>
    10441035<p>This either means that the username and password information in your <code>wp-config.php</code> file is incorrect or we can't contact the database server at <code>%s</code>. This could mean your host's database server is down.</p>
     
    10481039        <li>Are you sure that the database server is running?</li>
    10491040</ul>
    10501041<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>
    1051 "/*/WP_I18N_DB_CONN_ERROR*/, $details['db_host'] ), 'db_connect_fail' );
     1042"/*/WP_I18N_DB_CONN_ERROR*/, $this->dbhost ), 'db_connect_fail' );
    10521043                }
    1053                 $this->select( $details[ 'db_name' ], $this->$dbhname );
     1044
     1045                $this->set_charset( $this->dbh );
     1046
     1047                $this->ready = true;
     1048
     1049                $this->select( $this->dbname, $this->dbh );
    10541050        }
    10551051
    10561052        /**
     
    10831079                if ( defined( 'SAVEQUERIES' ) && SAVEQUERIES )
    10841080                        $this->timer_start();
    10851081
    1086                 // use $this->dbh for read ops, and $this->dbhwrite for write ops
    1087                 // use $this->dbhglobal for gloal table ops
    1088                 unset( $dbh );
    1089                 if( defined( 'WP_USE_MULTIPLE_DB' ) && WP_USE_MULTIPLE_DB ) {
    1090                         if( $this->blogs != '' && preg_match("/(" . $this->blogs . "|" . $this->users . "|" . $this->usermeta . "|" . $this->site . "|" . $this->sitemeta . "|" . $this->sitecategories . ")/i",$query) ) {
    1091                                 if( false == isset( $this->dbhglobal ) ) {
    1092                                         $this->db_connect( $query );
    1093                                 }
    1094                                 $dbh =& $this->dbhglobal;
    1095                                 $this->last_db_used = "global";
    1096                         } elseif ( preg_match("/^\\s*(alter table|create|insert|delete|update|replace) /i",$query) ) {
    1097                                 if( false == isset( $this->dbhwrite ) ) {
    1098                                         $this->db_connect( $query );
    1099                                 }
    1100                                 $dbh =& $this->dbhwrite;
    1101                                 $this->last_db_used = "write";
    1102                         } else {
    1103                                 $dbh =& $this->dbh;
    1104                                 $this->last_db_used = "read";
    1105                         }
    1106                 } else {
    1107                         $dbh =& $this->dbh;
    1108                         $this->last_db_used = "other/read";
    1109                 }
    1110 
    1111                 $this->result = @mysql_query( $query, $dbh );
     1082                $this->result = @mysql_query( $query, $this->dbh );
    11121083                $this->num_queries++;
    11131084
    11141085                if ( defined( 'SAVEQUERIES' ) && SAVEQUERIES )
    11151086                        $this->queries[] = array( $query, $this->timer_stop(), $this->get_caller() );
    11161087
    11171088                // If there is an error then take note of it..
    1118                 if ( $this->last_error = mysql_error( $dbh ) ) {
     1089                if ( $this->last_error = mysql_error( $this->dbh ) ) {
    11191090                        $this->print_error();
    11201091                        return false;
    11211092                }
    11221093
    11231094                if ( preg_match( "/^\\s*(insert|delete|update|replace|alter) /i", $query ) ) {
    1124                         $this->rows_affected = mysql_affected_rows( $dbh );
     1095                        $this->rows_affected = mysql_affected_rows( $this->dbh );
    11251096                        // Take note of the insert_id
    11261097                        if ( preg_match( "/^\\s*(insert|replace) /i", $query ) ) {
    1127                                 $this->insert_id = mysql_insert_id($dbh);
     1098                                $this->insert_id = mysql_insert_id($this->dbh);
    11281099                        }
    11291100                        // Return number of rows affected
    11301101                        $return_val = $this->rows_affected;
     
    15441515                        case 'group_concat' : // @since 2.7
    15451516                        case 'subqueries' :   // @since 2.7
    15461517                                return version_compare( $version, '4.1', '>=' );
     1518                        case 'set_charset' :
     1519                                return version_compare($version, '5.0.7', '>=');
    15471520                };
    15481521
    15491522                return false;