| 
									
										
										
										
											2010-02-24 12:08:53 +00:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * @copyright NetMonsters <team@netmonsters.ru> | 
					
						
							|  |  |  |  * @link http://netmonsters.ru | 
					
						
							|  |  |  |  * @package Majestic | 
					
						
							|  |  |  |  * @subpackage db | 
					
						
							|  |  |  |  * @since 2010-02-19 | 
					
						
							|  |  |  |  * @version SVN: $Id$ | 
					
						
							|  |  |  |  * @filesource $URL$ | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | abstract class DbStatement | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @var DbDriver | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected $driver; | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @var string | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:12 +04:00
										 |  |  |     protected $request; | 
					
						
							| 
									
										
										
										
											2010-02-24 12:08:53 +00:00
										 |  |  |      | 
					
						
							|  |  |  |     protected $params = array(); | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     protected $result; | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:12 +04:00
										 |  |  |     public function __construct($driver, $request) | 
					
						
							| 
									
										
										
										
											2010-02-24 12:08:53 +00:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:12 +04:00
										 |  |  |         $this->driver       = $driver; | 
					
						
							|  |  |  |         $this->request    = $request; | 
					
						
							| 
									
										
										
										
											2010-02-24 12:08:53 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param array $params | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function execute($params = null) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (is_array($params)) { | 
					
						
							|  |  |  |             foreach ($params as $param => &$value) { | 
					
						
							|  |  |  |                 $this->bindParam($param, $value); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return $this->driverExecute($this->assemble()); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:12 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-24 12:08:53 +00:00
										 |  |  |     public function __destruct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->close(); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2010-03-13 23:33:46 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param mixed $style | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function fetchAll($style = Db::FETCH_OBJ) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $data = array(); | 
					
						
							|  |  |  |         while ($row = $this->fetch($style)) { | 
					
						
							|  |  |  |             $data[] = $row; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return $data; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param string $field | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-03-17 20:52:23 +00:00
										 |  |  |     public function fetchColumn($field) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $data = array(); | 
					
						
							|  |  |  |         while ($row = $this->fetch(Db::FETCH_ASSOC)) { | 
					
						
							|  |  |  |             $data[] = $row[$field]; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return $data; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param string $field | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-03-13 23:33:46 +00:00
										 |  |  |     public function fetchField($field) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $row = $this->fetch(Db::FETCH_ASSOC); | 
					
						
							|  |  |  |         if (isset($row[$field])) { | 
					
						
							|  |  |  |             return $row[$field]; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return false; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2010-02-24 12:08:53 +00:00
										 |  |  |      | 
					
						
							| 
									
										
										
										
											2010-07-19 15:06:01 +00:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-03-23 15:47:32 +00:00
										 |  |  |     public function fetchPairs() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2010-03-27 00:01:27 +00:00
										 |  |  |         $data = array(); | 
					
						
							| 
									
										
										
										
											2010-03-23 15:47:32 +00:00
										 |  |  |         while ($row = $this->fetch(Db::FETCH_NUM)) { | 
					
						
							|  |  |  |             $data[$row[0]] = $row[1]; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return $data; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2010-02-24 12:08:53 +00:00
										 |  |  |     /* Abstract methods */ | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:12 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     abstract public function bindParam($param, &$value); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     abstract protected function assemble(); | 
					
						
							| 
									
										
										
										
											2010-02-24 12:08:53 +00:00
										 |  |  |      | 
					
						
							|  |  |  |     abstract public function fetch($style = Db::FETCH_OBJ); | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     abstract public function fetchObject($class = 'stdClass'); | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     abstract public function close(); | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @return int | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     abstract public function affectedRows(); | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     abstract public function numRows(); | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:12 +04:00
										 |  |  |     abstract protected function driverExecute($request); | 
					
						
							| 
									
										
										
										
											2010-07-19 15:06:01 +00:00
										 |  |  | } |