| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * @copyright NetMonsters <team@netmonsters.ru> | 
					
						
							|  |  |  |  * @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 $table | 
					
						
							| 
									
										
										
										
											2012-10-19 20:15:26 +04:00
										 |  |  |      * @param mixed $data | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |      * @param mixed $on_duplicate | 
					
						
							|  |  |  |      * @return int Affected rows count | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2011-11-18 13:59:36 +04:00
										 |  |  |     public function insert($table, $data, $on_duplicate = array()) | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |     { | 
					
						
							|  |  |  |         $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 | 
					
						
							| 
									
										
										
										
											2012-10-19 20:15:26 +04:00
										 |  |  |      * @param array $data | 
					
						
							|  |  |  |      * @param mixed $condition | 
					
						
							|  |  |  |      * @return int Number of updated rows | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     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 | 
					
						
							| 
									
										
										
										
											2012-10-19 20:15:26 +04:00
										 |  |  |      * @param mixed $condition | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |      * @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); | 
					
						
							|  |  |  |         foreach ($ident as &$segment) { | 
					
						
							| 
									
										
										
										
											2013-10-09 08:59:54 +04:00
										 |  |  |             if (!preg_match('/(\?|:[A-z][A-z0-9_]*+)/u', $segment)) { | 
					
						
							| 
									
										
										
										
											2013-09-26 10:46:30 +04:00
										 |  |  |                 $segment = $this->identifier_quote . $segment . $this->identifier_quote; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |         } | 
					
						
							|  |  |  |         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 | 
					
						
							| 
									
										
										
										
											2013-09-20 22:11:54 +04:00
										 |  |  |      * @throws ErrorException | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2013-09-20 22:11:54 +04:00
										 |  |  |     public function whereExpr($where) | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |     { | 
					
						
							|  |  |  |         if (empty($where)) { | 
					
						
							|  |  |  |             return $where; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (!is_array($where)) { | 
					
						
							|  |  |  |             $where = array($where); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         foreach ($where as $cond => &$term) { | 
					
						
							|  |  |  |             if (is_int($cond)) { | 
					
						
							| 
									
										
										
										
											2013-09-20 22:11:54 +04:00
										 |  |  |                 if (is_int($term)) { | 
					
						
							| 
									
										
										
										
											2013-09-26 10:46:30 +04:00
										 |  |  |                     throw new ErrorException('Condition in where expression as integer. ' . $term); | 
					
						
							| 
									
										
										
										
											2013-09-20 22:11:54 +04:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |                 if ($term instanceof DbExpr) { | 
					
						
							|  |  |  |                     $term = (string) $term; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } else { | 
					
						
							| 
									
										
										
										
											2013-09-20 22:11:54 +04:00
										 |  |  |                 if (is_array($term)) { | 
					
						
							|  |  |  |                     $term = new DbExpr('(' . implode(',', array_map(function($item){return intval($item);}, $term)) . ')'); | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |                 $term = $this->quoteInto($cond, $term); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return implode(' AND ', $where); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-20 22:11:54 +04:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param $select array | 
					
						
							|  |  |  |      * @param $distinct string|bool | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function selectExpr($select, $distinct = false) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (empty($distinct) && empty($select)) { | 
					
						
							|  |  |  |             return '*'; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (!is_array($select)) { | 
					
						
							|  |  |  |             $select = array($select); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if ($distinct) { | 
					
						
							|  |  |  |             $distinct = ((is_bool($distinct)) ? '*' : $this->quoteIdentifier($distinct)); | 
					
						
							|  |  |  |             array_unshift($select, new DbExpr('DISTINCT ' . $distinct)); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         foreach ($select as $field => &$term) { | 
					
						
							|  |  |  |             if (is_int($field)) { | 
					
						
							|  |  |  |                 if ($term instanceof DbExpr) { | 
					
						
							|  |  |  |                     $term = (string) $term; | 
					
						
							|  |  |  |                 } else { | 
					
						
							|  |  |  |                     $term = $this->quoteIdentifier($term); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } else { | 
					
						
							|  |  |  |                 $term = $this->quoteIdentifier($field) . ' as ' . $this->quoteIdentifier($term); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return implode(',', $select); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function limitExpr($limit) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (empty($limit)) { | 
					
						
							|  |  |  |             return $limit; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return implode(',',array_map(function($item){return intval($item);},explode(',',$limit))); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-11 18:01:17 +04:00
										 |  |  |     abstract protected function driverQuote($value); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     abstract protected function driverBeginTransaction(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     abstract protected function driverCommitTransaction(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     abstract protected function driverRollbackTransaction(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  |      |