public function Select::compile

Compiles the saved conditions for later retrieval.

This method does not return anything, but simply prepares data to be retrieved via __toString() and arguments().

Parameters

$connection: The database connection for which to compile the conditionals.

$queryPlaceholder: The query this condition belongs to. If not given, the current query is used.

Overrides ConditionInterface::compile

2 calls to Select::compile()
Select::getArguments in drupal/core/lib/Drupal/Core/Database/Query/Select.php
Compiles and returns an associative array of the arguments for this prepared statement.
Select::__toString in drupal/core/lib/Drupal/Core/Database/Query/Select.php
Implements PHP magic __toString method to convert the query to a string.

File

drupal/core/lib/Drupal/Core/Database/Query/Select.php, line 229
Definition of Drupal\Core\Database\Query\Select

Class

Select
Query builder for SELECT statements.

Namespace

Drupal\Core\Database\Query

Code

public function compile(Connection $connection, PlaceholderInterface $queryPlaceholder) {
  $this->where
    ->compile($connection, $queryPlaceholder);
  $this->having
    ->compile($connection, $queryPlaceholder);
  foreach ($this->tables as $table) {

    // If this table is a subquery, compile it recursively.
    if ($table['table'] instanceof SelectInterface) {
      $table['table']
        ->compile($connection, $queryPlaceholder);
    }
  }

  // If there are any dependent queries to UNION, compile it recursively.
  foreach ($this->union as $union) {
    $union['query']
      ->compile($connection, $queryPlaceholder);
  }
}