W3cubDocs

/Drupal 8

public function Select::preExecute

public Select::preExecute(SelectInterface $query = NULL)

Generic preparation and validation for a SELECT query.

Return value

TRUE if the validation was successful, FALSE if not.

Overrides SelectInterface::preExecute

File

core/lib/Drupal/Core/Database/Query/Select.php, line 446

Class

Select
Query builder for SELECT statements.

Namespace

Drupal\Core\Database\Query

Code

public function preExecute(SelectInterface $query = NULL) {
  // If no query object is passed in, use $this.
  if (!isset($query)) {
    $query = $this;
  }

  // Only execute this once.
  if ($query->isPrepared()) {
    return TRUE;
  }

  // Modules may alter all queries or only those having a particular tag.
  if (isset($this->alterTags)) {
    $hooks = array('query');
    foreach ($this->alterTags as $tag => $value) {
      $hooks[] = 'query_' . $tag;
    }
    \Drupal::moduleHandler()->alter($hooks, $query);
  }

  $this->prepared = TRUE;

  // Now also prepare any sub-queries.
  foreach ($this->tables as $table) {
    if ($table['table'] instanceof SelectInterface) {
      $table['table']->preExecute();
    }
  }

  foreach ($this->union as $union) {
    $union['query']->preExecute();
  }

  return $this->prepared;
}

© 2001–2016 by the original authors
Licensed under the GNU General Public License, version 2 and later.
Drupal is a registered trademark of Dries Buytaert.
https://api.drupal.org/api/drupal/core!lib!Drupal!Core!Database!Query!Select.php/function/Select::preExecute/8.1.x