This plugin hasn’t been tested with the latest three major releases of WordPress. It may no longer be maintained or supported and may have compatibility issues when used with more recent versions of WordPress.

MySQL Profiler

Description

MySQL Profiler displays debugging information about SQL queries to admin WordPress users. For each query, the profiler displays the time, syntax-highlighted SQL, and a trace of the functions (as well as the file and line number that the functions were called from) that were called.

The list can be sorted by any of its columns, so you can, for example:

  • Order the list by ID to see the chronological order of the queries
  • Order the list by time to see the slowest queries
  • Order the list by query to group the queries by type (SELECT, UPDATE, etc)
  • Order the list by trace to group the queries by similar origins

The list can also filtered by typing in the search box, so you can, for example:

  • View all queries that use the wp_posts table
  • View all queries that are related to the use of a function in taxonomy.php
  • View all queries that are related to the use of a specific function or class
  • View all queries that call a specific MySQL function

To turn off syntax highlighting, put the following in wp-config.php:

define('MP_HIGHLIGHT_SYNTAX', false);

To omit the file and line number from the function trace and display the functions as a comma-separated list (to save vertical space), define the following in wp-config.php:

define('MP_DISPLAY_FILES', false);

This plugin was loosely based on Frank Bueltge‘s Debug Queries plugin, so a hearty thanks to him for the development of that.

If you’d like to grab development releases, see what new features are being added, or browse the source code please visit/follow the GitHub repo.

Screenshots

  • Profiling for a typical single post page, filtered to show only queries containing references to wp_posts and ordered by the time column to show the slowest queries at the top.
  • Profiling for a typical single post page, with syntax highlighting turned off and the display of file and line numbers turned off (by setting MP_DISPLAY_FILES and MP_HIGHLIGHT_SYNTAX to false).

Installation

  1. Put mysql-profiler into the wp-content/plugins directory
  2. Activate the plugin in the “Plugins” menu in WordPress to turn on the profiling
  3. Deactivate when you’ve finished using the profiling

FAQ

Is feature X available?

If there’s widely-needed functionality that you’d like that isn’t implemented, I’d likely be willing to implement it myself or to accept any well-written code that implements it. Please feel free to either add a topic in the WordPress forum or contact me through GitHub for any such requests:

Reviews

25 June 2020
I have no idea how to make this work. There is no documentation and no links in the admin left menu. Lots of error messages when I look at the home page.
Read all 5 reviews

Contributors and Developers

“MySQL Profiler” is open source software. The following people have contributed to this plugin.

Contributors

Translate “MySQL Profiler” into your language.

Interested in development?

Browse the code, check out the SVN repository, or subscribe to the development log by RSS.