* @link http://netmonsters.ru * @package Majestic * @subpackage db * @since 2011-11-11 */ abstract class SqlDbDriver extends DbDriver { protected $identifier_quote = '`'; public function beginTransaction() { $this->connect(); $this->driverBeginTransaction(); return $this; } public function commit() { $this->connect(); $this->driverCommitTransaction(); return $this; } public function rollback() { $this->connect(); $this->driverRollbackTransaction(); return $this; } /** * @param string $sql * @param mixed $params * @return DbStatement */ public function query($sql, $params = array()) { $this->connect(); if (!is_array($params)) { $params = array($params); } $stmt = $this->prepare($sql); $stmt->execute($params); return $stmt; } /** * @param string $table * @param mixed $bind * @param mixed $on_duplicate * @return int Affected rows count */ public function insert($table, $data) { $columns = array(); foreach ($data as $col => $val) { $columns[] = $this->quoteIdentifier($col); } $values = array_values($data); $sql = 'INSERT INTO ' . $this->quoteIdentifier($table) . ' (' . implode(', ', $columns) . ') VALUES (' . $this->quote($values) . ')'; return $this->query($sql)->affectedRows(); } /** * @param string $table * @param array $bind * @param mixed $where * @return int */ public function update($table, $data, $condition = '') { $set = array(); foreach ($data as $col => $val) { $set[] = $this->quoteIdentifier($col) . '=' . $this->quote($val); } $where = $this->whereExpr($condition); $sql = 'UPDATE ' . $this->quoteIdentifier($table) . ' SET ' . implode(', ', $set) . (($where) ? (' WHERE ' . $where) : ''); return $this->query($sql)->affectedRows(); } /** * @param string $table * @param mixed $where * @return int */ public function delete($table, $condition = '') { $where = $this->whereExpr($condition); $sql = 'DELETE FROM ' . $this->quoteIdentifier($table) . (($where) ? (' WHERE ' . $where) : ''); return $this->query($sql)->affectedRows(); } /** * @param mixed $value * @return string */ public function quote($value) { if ($value instanceof DbExpr) { return (string) $value; } if (is_array($value)) { foreach ($value as &$val) { $val = $this->quote($val); } return implode(', ', $value); } return $this->driverQuote($value); } /** * @param string $ident * @return string */ public function quoteIdentifier($ident) { $ident = explode('.', $ident); if (!is_array($ident)) { $ident = array($ident); } foreach ($ident as &$segment) { $segment = $this->identifier_quote . $segment . $this->identifier_quote; } return implode('.', $ident); } public function quoteInto($text, $value) { $pos = mb_strpos($text, '?'); if ($pos === false) { return $text; } return mb_substr($text, 0, $pos) . $this->quote($value) . mb_substr($text, $pos + 1); } /** * @param mixed $where * @return string */ protected function whereExpr($where) { if (empty($where)) { return $where; } if (!is_array($where)) { $where = array($where); } foreach ($where as $cond => &$term) { if (is_int($cond)) { if ($term instanceof DbExpr) { $term = (string) $term; } } else { $term = $this->quoteInto($cond, $term); } } return implode(' AND ', $where); } /** * @return DbStatement */ abstract public function prepare($sql); abstract protected function driverQuote($value); abstract protected function driverBeginTransaction(); abstract protected function driverCommitTransaction(); abstract protected function driverRollbackTransaction(); }