Skip to content

Commit

Permalink
[8.x] Add explain() to Query\Builder and Eloquent\Builder (#34969)
Browse files Browse the repository at this point in the history
* trait

* use trait

* Update Builder.php

* Update Builder.php

Co-authored-by: Taylor Otwell <taylor@laravel.com>
  • Loading branch information
hivokas and taylorotwell committed Oct 26, 2020
1 parent 55044ab commit c393ca2
Show file tree
Hide file tree
Showing 3 changed files with 28 additions and 2 deletions.
24 changes: 24 additions & 0 deletions src/Illuminate/Database/Concerns/ExplainsQueries.php
@@ -0,0 +1,24 @@
<?php

namespace Illuminate\Database\Concerns;

use Illuminate\Support\Collection;

trait ExplainsQueries
{
/**
* Explains the query.
*
* @return \Illuminate\Support\Collection
*/
public function explain()
{
$sql = $this->toSql();

$bindings = $this->getBindings();

$explanation = $this->getConnection()->select('EXPLAIN '.$sql, $bindings);

return new Collection($explanation);
}
}
3 changes: 2 additions & 1 deletion src/Illuminate/Database/Eloquent/Builder.php
Expand Up @@ -7,6 +7,7 @@
use Exception;
use Illuminate\Contracts\Support\Arrayable;
use Illuminate\Database\Concerns\BuildsQueries;
use Illuminate\Database\Concerns\ExplainsQueries;
use Illuminate\Database\Eloquent\Relations\Relation;
use Illuminate\Database\Query\Builder as QueryBuilder;
use Illuminate\Pagination\Paginator;
Expand All @@ -23,7 +24,7 @@
*/
class Builder
{
use BuildsQueries, Concerns\QueriesRelationships, ForwardsCalls;
use BuildsQueries, Concerns\QueriesRelationships, ExplainsQueries, ForwardsCalls;

/**
* The base query builder instance.
Expand Down
3 changes: 2 additions & 1 deletion src/Illuminate/Database/Query/Builder.php
Expand Up @@ -6,6 +6,7 @@
use DateTimeInterface;
use Illuminate\Contracts\Support\Arrayable;
use Illuminate\Database\Concerns\BuildsQueries;
use Illuminate\Database\Concerns\ExplainsQueries;
use Illuminate\Database\ConnectionInterface;
use Illuminate\Database\Eloquent\Builder as EloquentBuilder;
use Illuminate\Database\Eloquent\Relations\Relation;
Expand All @@ -23,7 +24,7 @@

class Builder
{
use BuildsQueries, ForwardsCalls, Macroable {
use BuildsQueries, ExplainsQueries, ForwardsCalls, Macroable {
__call as macroCall;
}

Expand Down

0 comments on commit c393ca2

Please sign in to comment.