public function DatabaseConnection_sqlite::rollback in Drupal 7
Rolls back the transaction entirely or to a named savepoint.
This method throws an exception if no transaction is active.
Parameters
$savepoint_name: The name of the savepoint. The default, 'drupal_transaction', will roll the entire transaction back.
Throws
DatabaseTransactionNoActiveException
Overrides DatabaseConnection::rollback
See also
DatabaseTransaction::rollback()
File
- includes/
database/ sqlite/ database.inc, line 323 - Database interface code for SQLite embedded database engine.
Class
- DatabaseConnection_sqlite
- Specific SQLite implementation of DatabaseConnection.
Code
public function rollback($savepoint_name = 'drupal_transaction') {
if ($this->savepointSupport) {
return parent::rollBack($savepoint_name);
}
if (!$this
->inTransaction()) {
throw new DatabaseTransactionNoActiveException();
}
// A previous rollback to an earlier savepoint may mean that the savepoint
// in question has already been rolled back.
if (!in_array($savepoint_name, $this->transactionLayers)) {
return;
}
// We need to find the point we're rolling back to, all other savepoints
// before are no longer needed.
while ($savepoint = array_pop($this->transactionLayers)) {
if ($savepoint == $savepoint_name) {
// Mark whole stack of transactions as needed roll back.
$this->willRollback = TRUE;
// If it is the last the transaction in the stack, then it is not a
// savepoint, it is the transaction itself so we will need to roll back
// the transaction rather than a savepoint.
if (empty($this->transactionLayers)) {
break;
}
return;
}
}
if ($this
->supportsTransactions()) {
$this->connection
->rollBack();
}
}