/** * Method to commit a transaction. * * @param boolean $toSavepoint If true, commit to the last savepoint. * @return self Returns this object to support chaining. * * @throws \RuntimeException */ public function transactionCommit($toSavepoint = false) { if (version_compare($this->cmsRelease, '3.2', '>=')) { $this->_db->transactionCommit($toSavepoint); } else { if (!$toSavepoint || $this->transactionDepth <= 1) { $this->_db->transactionCommit(); $this->transactionDepth = 0; return $this; } $this->transactionDepth--; } return $this; }
/** * Do delete action, this method should be override by sub class. * * @param mixed $conditions Where conditions, you can use array or Compare object. * * @throws \Exception * @return boolean Will be always true. */ protected function doDelete(array $conditions) { $query = $this->db->getQuery(true); // Conditions. QueryHelper::buildWheres($query, $conditions); $query->delete($this->table); $this->db->transactionStart(true); try { $result = (bool) $this->db->setQuery($query)->execute(); } catch (\Exception $e) { $this->db->transactionRollback(true); throw $e; } $this->db->transactionCommit(true); return $result; }
/** * transactionCommit * * @param bool $asSavePoint * * @return $this */ public function transactionCommit($asSavePoint = false) { $this->db->transactionCommit($asSavePoint); }