interface StatementInterface
Same name and namespace in other branches
- 11.x core/lib/Drupal/Core/Database/StatementInterface.php \Drupal\Core\Database\StatementInterface
- 10 core/lib/Drupal/Core/Database/StatementInterface.php \Drupal\Core\Database\StatementInterface
- 9 core/lib/Drupal/Core/Database/StatementInterface.php \Drupal\Core\Database\StatementInterface
- 8.9.x core/lib/Drupal/Core/Database/StatementInterface.php \Drupal\Core\Database\StatementInterface
Represents a prepared statement.
Child implementations should either extend StatementBase:
class \Drupal\my_module\Driver\Database\my_driver\Statement extends \Drupal\Core\Database\Statement\StatementBase {}
or define their own class. If defining their own class, they will also have to implement either the \Iterator or \IteratorAggregate interface before Drupal\Core\Database\StatementInterface:
class \Drupal\my_module\Driver\Database\my_driver\Statement implements \Iterator, \Drupal\Core\Database\StatementInterface {}
Hierarchy
- interface \Drupal\Core\Database\StatementInterface extends \Drupal\Core\Database\Traversable
Expanded class hierarchy of StatementInterface
All classes that implement StatementInterface
Related topics
12 files declare their use of StatementInterface
- Connection.php in core/
modules/ sqlite/ src/ Driver/ Database/ sqlite/ Connection.php - Connection.php in core/
modules/ pgsql/ src/ Driver/ Database/ pgsql/ Connection.php - ExceptionHandler.php in core/
modules/ mysqli/ src/ Driver/ Database/ mysqli/ ExceptionHandler.php - ExceptionHandler.php in core/
modules/ mysql/ src/ Driver/ Database/ mysql/ ExceptionHandler.php - FetchTest.php in core/
tests/ Drupal/ KernelTests/ Core/ Database/ FetchTest.php
File
-
core/
lib/ Drupal/ Core/ Database/ StatementInterface.php, line 23
Namespace
Drupal\Core\DatabaseView source
interface StatementInterface extends \Traversable {
/**
* Executes a prepared statement.
*
* @param array|null $args
* (Optional) An array of values with as many elements as there are bound
* parameters in the SQL statement being executed. This can be NULL.
* @param array $options
* (Optional) An array of options for this query.
*
* @return bool
* TRUE on success, or FALSE on failure.
*/
public function execute(?array $args = [], array $options = []);
/**
* Gets the query string of this statement.
*
* @return string
* The query string, in its form with placeholders.
*/
public function getQueryString();
/**
* Returns the target connection this statement is associated with.
*
* @return string
* The target connection string of this statement.
*/
public function getConnectionTarget() : string;
/**
* Returns the number of rows matched by the last SQL statement.
*
* @return int
* The number of rows matched by the last DELETE, INSERT, or UPDATE
* statement executed or throws \Drupal\Core\Database\RowCountException
* if the last executed statement was SELECT.
*
* @throws \Drupal\Core\Database\RowCountException
*/
public function rowCount();
/**
* Sets the default fetch mode for this statement.
*
* @param \Drupal\Core\Database\Statement\FetchAs $mode
* One of the cases of the FetchAs enum.
* @param string|int|null $a1
* (Optional) An option depending of the fetch mode specified by $mode:
* - for FetchAs::Column, the index of the column to fetch;
* - for FetchAs::ClassObject, the name of the class to create.
* @param list<mixed> $a2
* (Optional) If $mode is FetchAs::ClassObject, the optional arguments to
* pass to the constructor.
*
* @return bool
* TRUE if successful, FALSE if not.
*/
public function setFetchMode(FetchAs $mode, string|int|null $a1 = NULL, array $a2 = []);
/**
* Fetches the next row from a result set.
*
* @param \Drupal\Core\Database\Statement\FetchAs|null $mode
* (Optional) one of the cases of the FetchAs enum. If not specified,
* defaults to what is specified by setFetchMode().
*
* @return array|object|false
* A result, formatted according to $mode, or FALSE on failure.
*/
public function fetch(?FetchAs $mode = NULL);
/**
* Returns a single column value from the next record of a result set.
*
* @param int $index
* (Optional) The numeric index of the column to return. Defaults to the
* first one.
*
* @return mixed
* A single column value from the next record, or FALSE if there is no next
* record.
*
* @throws \ValueError
* If there is a record and the column index is not defined.
*/
public function fetchField(int $index = 0);
/**
* Fetches the next row and returns it as an object.
*
* The object will be of the class specified by
* StatementInterface::setFetchMode() or stdClass if not specified.
*
* @param string|null $class_name
* (Optional) Name of the created class.
* @param array $constructor_arguments
* (Optional) Elements of this array are passed to the constructor.
*
* @return object|false|null
* The object of specified class or \stdClass if not specified. Returns
* FALSE or NULL if there is no next row.
*/
public function fetchObject(?string $class_name = NULL, array $constructor_arguments = []);
/**
* Fetches the next row and returns it as an associative array.
*
* This method corresponds to \PDOStatement::fetchObject(), but for
* associative arrays. For some reason \PDOStatement does not have a
* corresponding array helper method, so one is added.
*
* @return array|false
* An associative array, or FALSE if there is no next row.
*/
public function fetchAssoc();
/**
* Returns an array containing all of the result set rows.
*
* @param \Drupal\Core\Database\Statement\FetchAs|null $mode
* (Optional) one of the cases of the FetchAs enum. If not specified,
* defaults to what is specified by setFetchMode().
* @param int|null $column_index
* (Optional) If $mode is FetchAs::Column, the index of the column to
* fetch.
* @param array|null $constructor_arguments
* (Optional) If $mode is FetchAs::ClassObject, the arguments to pass to
* the constructor.
*
* @return array
* An array of results.
*/
public function fetchAll(?FetchAs $mode = NULL, ?int $column_index = NULL, ?array $constructor_arguments = NULL);
/**
* Returns an entire single column of a result set as an indexed array.
*
* Note that this method will run the result set to the end.
*
* @param int $index
* (Optional) The index of the column number to fetch. By default, the
* first one.
*
* @return array
* An indexed array, or an empty array if there is no result set.
*
* @throws \ValueError
* If there is at least one record but the column index is not defined.
*/
public function fetchCol(int $index = 0);
/**
* Returns the entire result set as a single associative array.
*
* This method is only useful for two-column result sets. It will return an
* associative array where the key is one column from the result set and the
* value is another column. In most cases, the default of the first two
* columns is appropriate.
*
* Note that this method will run the result set to the end.
*
* @param int $key_index
* (Optional) The numeric index of the column to use as the array key. By
* default, the first column.
* @param int $value_index
* (Optional) The numeric index of the column to use as the array value. By
* default, the second column.
*
* @return array
* An associative array, or an empty array if there is no result set.
*/
public function fetchAllKeyed(int $key_index = 0, int $value_index = 1);
/**
* Returns the result set as an associative array keyed by the given column.
*
* If the given key appears multiple times, later records will overwrite
* earlier ones.
*
* Note that this method will run the result set to the end.
*
* @param string $key
* The name of the column on which to index the array.
* @param \Drupal\Core\Database\Statement\FetchAs|null $fetch
* (Optional) the fetch mode to use. One of the cases of the FetchAs enum.
* If set to FetchAs::Associative or FetchAs::List the returned value will
* be an array of arrays. For any other value it will be an array of
* objects. If not specified, defaults to what is specified by
* setFetchMode().
*
* @return array
* An associative array, or an empty array if there is no result set.
*/
public function fetchAllAssoc(string $key, ?FetchAs $fetch = NULL);
}
Members
| Title Sort descending | Modifiers | Object type | Summary | Overrides |
|---|---|---|---|---|
| StatementInterface::execute | public | function | Executes a prepared statement. | 1 |
| StatementInterface::fetch | public | function | Fetches the next row from a result set. | 1 |
| StatementInterface::fetchAll | public | function | Returns an array containing all of the result set rows. | 1 |
| StatementInterface::fetchAllAssoc | public | function | Returns the result set as an associative array keyed by the given column. | 1 |
| StatementInterface::fetchAllKeyed | public | function | Returns the entire result set as a single associative array. | 1 |
| StatementInterface::fetchAssoc | public | function | Fetches the next row and returns it as an associative array. | 1 |
| StatementInterface::fetchCol | public | function | Returns an entire single column of a result set as an indexed array. | 1 |
| StatementInterface::fetchField | public | function | Returns a single column value from the next record of a result set. | 1 |
| StatementInterface::fetchObject | public | function | Fetches the next row and returns it as an object. | 1 |
| StatementInterface::getConnectionTarget | public | function | Returns the target connection this statement is associated with. | 1 |
| StatementInterface::getQueryString | public | function | Gets the query string of this statement. | 1 |
| StatementInterface::rowCount | public | function | Returns the number of rows matched by the last SQL statement. | 1 |
| StatementInterface::setFetchMode | public | function | Sets the default fetch mode for this statement. | 1 |
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.