EXPLAIN command
EXPLAIN is a command that produces the query plan Postgres will use to execute a query. This allows you to check that the query is optimal, before running it.
PgDog can annotate the query plan returned by Postgres with its own routing decision. This allows you to check which shard(s) the query will be sent to, and if it will be sent to the primary or a replica.
How it works
To avoid breaking existing tooling which relies on the standard EXPLAIN format, PgDog's EXPLAIN is disabled by default and can be turned on with configuration:
When configured, all EXPLAIN queries will start returning two query plans: one for Postgres and one for PgDog. For example:
Query plan
PgDog's query plan contains the following information:
| Name | Description | 
|---|---|
| shard | The shard number(s) where the query will be sent. | 
| role | Whether the query will go to a replica or the primary. | 
For each shard, an additional note will be returned, explaining the decision to include it in the query plan. For cross-shard queries, a note will indicate why the query has to be sent to all shards, for example: