Database: Don't generate unnecessary warnings in `wpdb::query()`.
In the event that the database has gone away for some reason, calls to `mysqli_errno()` and `mysqli_error()` (and their `ext/mysql` equivalents, of course), will generate PHP warnings, which are unsightly, and not how we do things in these parts. Props mbijon, craig-ralston for the original patch. Fixes #23085. Built from https://develop.svn.wordpress.org/trunk@37548 git-svn-id: http://core.svn.wordpress.org/trunk@37516 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
6c405b8f36
commit
2441b7b52f
|
@ -4,7 +4,7 @@
|
||||||
*
|
*
|
||||||
* @global string $wp_version
|
* @global string $wp_version
|
||||||
*/
|
*/
|
||||||
$wp_version = '4.6-alpha-37547';
|
$wp_version = '4.6-alpha-37548';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
||||||
|
|
|
@ -1719,18 +1719,28 @@ class wpdb {
|
||||||
|
|
||||||
$this->check_current_query = true;
|
$this->check_current_query = true;
|
||||||
|
|
||||||
// Keep track of the last query for debug..
|
// Keep track of the last query for debug.
|
||||||
$this->last_query = $query;
|
$this->last_query = $query;
|
||||||
|
|
||||||
$this->_do_query( $query );
|
$this->_do_query( $query );
|
||||||
|
|
||||||
// MySQL server has gone away, try to reconnect
|
// MySQL server has gone away, try to reconnect.
|
||||||
$mysql_errno = 0;
|
$mysql_errno = 0;
|
||||||
if ( ! empty( $this->dbh ) ) {
|
if ( ! empty( $this->dbh ) ) {
|
||||||
if ( $this->use_mysqli ) {
|
if ( $this->use_mysqli ) {
|
||||||
|
if ( $this->dbh instanceof mysqli ) {
|
||||||
$mysql_errno = mysqli_errno( $this->dbh );
|
$mysql_errno = mysqli_errno( $this->dbh );
|
||||||
} else {
|
} else {
|
||||||
|
// $dbh is defined, but isn't a real connection.
|
||||||
|
// Something has gone horribly wrong, let's try a reconnect.
|
||||||
|
$mysql_errno = 2006;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if ( is_resource( $this->dbh ) ) {
|
||||||
$mysql_errno = mysql_errno( $this->dbh );
|
$mysql_errno = mysql_errno( $this->dbh );
|
||||||
|
} else {
|
||||||
|
$mysql_errno = 2006;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1743,11 +1753,19 @@ class wpdb {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// If there is an error then take note of it..
|
// If there is an error then take note of it.
|
||||||
if ( $this->use_mysqli ) {
|
if ( $this->use_mysqli ) {
|
||||||
|
if ( $this->dbh instanceof mysqli ) {
|
||||||
$this->last_error = mysqli_error( $this->dbh );
|
$this->last_error = mysqli_error( $this->dbh );
|
||||||
} else {
|
} else {
|
||||||
|
$this->last_error = __( 'Unable to retrieve the error message from MySQL' );
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if ( is_resource( $this->dbh ) ) {
|
||||||
$this->last_error = mysql_error( $this->dbh );
|
$this->last_error = mysql_error( $this->dbh );
|
||||||
|
} else {
|
||||||
|
$this->last_error = __( 'Unable to retrieve the error message from MySQL' );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( $this->last_error ) {
|
if ( $this->last_error ) {
|
||||||
|
|
Loading…
Reference in New Issue