I am using $wpdb->update
to update a custom table I have in my database. When I var_dump
the result it returns:
int(0)
So I tried $wpdb->print_error()
to see what’s wrong. However, it shows nothing. I also tried $wpdb->show_errors()
, but again it showed nothing.
The wpdb docs don’t go into much detail on how to use these functions, so I am unsure if I am using them correctly. But why would the result of updating a table return 0, and not show any errors?
I would recommend running the following code right after your query to see what’s happening:
This should print the last query that hit your database. In cases like these, I usually will manually run such a query through phpMyAdmin to see if it runs without errors and to see if it even affects the database. Additionally, by seeing the query that was actually run, you may find problems in the query that results from your code. For instance, the query may not return any MySQL errors, but it could run a query that is different than you expect it to be. With this debug code, you’ll at least be able to see what it is and continue on the wonderful debug trail! Furthermore, you may want to explore more of the “Class Variables” (Codex Ref) for
$wpdb
as they may help further troubleshoot your issue.Show errors:
$wpdb->show_errors = true
shows errors automatically, ifWP_DEBUG
is set totrue
.$wpdb->suppress_errors = false
stops suppressing errors.Multisite need special treatment
Output handling
The
$wpdb->update()
method has three different outputs. To check against it, you must save the result i a var:$result = $wpdb->update( /* ... */ );
.The handle those scenarios:
false === $result
: Fail0 === $result
: Success, but no update0 < $result
: SuccessClass output
$wpdb->last_error
will show you the last error, if you got one.$wpdb->last_query
will assist you with showing the last query (where the error occurred). It is basically the same asarray_pop( $wpbd->queries );
.Important (security) Note
Please do NOT add this codes on live site. Especially not if caching plugins are involved. This may expose important DB-related data to visitors!
If you can’t do otherwise: always wrap your code in conditional statements to prevent public facing debug output!
Exposing the
$wpdb
object might also expose your database username and password!A zero response means zero rows affected, which is different from an error.
Its hard to say without looking at your query why no rows are being updated. One debug tool you can try is setting “
SAVEQUERIES
” to true in your wp-config.php file.Then after your query runs, try
var_dump
ing$wpdb->queries
.Try this before your query:
or perhaps this after your query: