| 
									
										
										
										
											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$ | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * @property MySQLiDriver $driver | 
					
						
							|  |  |  |  * @property MySQLi_Result $result | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class MySQLiStatement extends DbStatement | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2010-03-13 23:33:46 +00:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Fetches single row | 
					
						
							|  |  |  |      *  | 
					
						
							|  |  |  |      * @param mixed $style | 
					
						
							|  |  |  |      * @return mixed | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-02-24 12:08:53 +00:00
										 |  |  |     public function fetch($style = Db::FETCH_OBJ) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2010-03-13 23:33:46 +00:00
										 |  |  |         if (!$this->result) { | 
					
						
							| 
									
										
										
										
											2010-02-24 12:08:53 +00:00
										 |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         $row = false; | 
					
						
							|  |  |  |         switch ($style) { | 
					
						
							|  |  |  |             case Db::FETCH_OBJ: | 
					
						
							|  |  |  |                 $row = $this->result->fetch_object(); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |             case Db::FETCH_NUM: | 
					
						
							|  |  |  |                 $row = $this->result->fetch_array(MYSQLI_NUM); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |             case Db::FETCH_ASSOC: | 
					
						
							|  |  |  |                 $row = $this->result->fetch_assoc(); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |             case Db::FETCH_BOTH: | 
					
						
							|  |  |  |                 $row = $this->result->fetch_array(MYSQLI_BOTH); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |             default: | 
					
						
							|  |  |  |                 throw new Exception('Invalid fetch mode "' . $style . '" specified'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return $row; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param string $class | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function fetchObject($class = 'stdClass') | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->result->fetch_object($class); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     public function close() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if ($this->result !== null) { | 
					
						
							|  |  |  |             $this->result->close(); | 
					
						
							|  |  |  |             $this->result = null; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     public function affectedRows() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->driver->getConnection()->affected_rows; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     public function numRows() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if ($this->result) { | 
					
						
							|  |  |  |             return $this->result->num_rows; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return false; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     protected function driverExecute($sql) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         /** | 
					
						
							|  |  |  |          * @var MySQLi | 
					
						
							|  |  |  |          */ | 
					
						
							|  |  |  |         $mysqli = $this->driver->getConnection(); | 
					
						
							| 
									
										
										
										
											2010-03-13 23:33:46 +00:00
										 |  |  |         if (DEBUG) { | 
					
						
							|  |  |  |             $profiler = Profiler::getInstance()->profilerQuery($sql); | 
					
						
							|  |  |  |             $result = $mysqli->query($sql); | 
					
						
							|  |  |  |             $profiler->end(); | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             $result = $mysqli->query($sql); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2010-02-24 12:08:53 +00:00
										 |  |  |         if ($result === false) { | 
					
						
							| 
									
										
										
										
											2010-05-24 13:54:50 +00:00
										 |  |  |             $message = $mysqli->error . "\nQuery: \"" . $sql . '"'; | 
					
						
							|  |  |  |             throw new Exception($message, $mysqli->errno); | 
					
						
							| 
									
										
										
										
											2010-02-24 12:08:53 +00:00
										 |  |  |         } | 
					
						
							|  |  |  |         if ($result instanceof MySQLi_Result) { | 
					
						
							|  |  |  |             $this->result = $result; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2010-05-24 13:54:50 +00:00
										 |  |  | } |