| 
									
										
										
										
											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 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * @property MySQLiDriver $driver | 
					
						
							|  |  |  |  * @property MySQLi_Result $result | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class MySQLiStatement extends DbStatement | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:12 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     protected $map = null; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function bindParam($param, &$value) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if ($this->map === null) { | 
					
						
							|  |  |  |             $this->mapPlaceholders(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (count($this->map) > 0) { | 
					
						
							|  |  |  |             if (!is_string($param) && !is_int($param)) { | 
					
						
							| 
									
										
										
										
											2011-12-06 14:16:13 +04:00
										 |  |  |                 throw new GeneralException('Placeholder must be an integer or string'); | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:12 +04:00
										 |  |  |             } | 
					
						
							|  |  |  |             if (is_object($value) && ! ($value instanceof DbExpr)) { | 
					
						
							| 
									
										
										
										
											2011-12-06 14:05:18 +04:00
										 |  |  |                 throw new GeneralException('Objects excepts DbExpr not allowed.'); | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:12 +04:00
										 |  |  |             } | 
					
						
							|  |  |  |             if (isset($this->map[$param])) { | 
					
						
							|  |  |  |                 $this->params[$param] = &$value; | 
					
						
							|  |  |  |                 return true; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return false; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     protected function mapPlaceholders() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $matches = array(); | 
					
						
							| 
									
										
										
										
											2013-10-09 08:35:15 +04:00
										 |  |  |         if(preg_match_all('/(\?|:[A-z][A-z0-9_]*+)/u', $this->request, $matches, PREG_OFFSET_CAPTURE)) { | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:12 +04:00
										 |  |  |             $noname = 0; | 
					
						
							|  |  |  |             foreach ($matches[0] as $id=>$match) { | 
					
						
							|  |  |  |                 $match[2] = $matches[1][$id][0]; | 
					
						
							|  |  |  |                 $name = ($match[2][0] === ':') ? ltrim($match[2], ':') : $noname++; | 
					
						
							|  |  |  |                 $this->map[$name]['placeholder'] = $match[0]; | 
					
						
							|  |  |  |                 $this->map[$name]['offset'][]    = $match[1]; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     protected function assemble() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (empty($this->map)) { | 
					
						
							|  |  |  |             return $this->request; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $query = $this->request; | 
					
						
							|  |  |  |         $placeholders = array(); | 
					
						
							|  |  |  |         foreach($this->map as $name => $place) { | 
					
						
							|  |  |  |             $value = $this->driver->quote($this->params[$name]); | 
					
						
							|  |  |  |             foreach ($place['offset'] as $offset) { | 
					
						
							|  |  |  |                 $placeholders[$offset] = array('placeholder' => $place['placeholder'], 'value' => $value); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         ksort($placeholders); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $increment = 0; | 
					
						
							|  |  |  |         foreach($placeholders as $current_offset => $placeholder) { | 
					
						
							|  |  |  |             $offset = $current_offset + $increment; | 
					
						
							|  |  |  |             $length = mb_strlen($placeholder['placeholder']); | 
					
						
							|  |  |  |             $query = mb_substr($query, 0, $offset) . $placeholder['value'] . mb_substr($query, $offset + $length); | 
					
						
							|  |  |  |             $increment = (($increment - $length) + mb_strlen($placeholder['value'])); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return $query; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-13 23:33:46 +00:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Fetches single row | 
					
						
							| 
									
										
										
										
											2011-12-05 20:11:20 +04:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2010-03-13 23:33:46 +00:00
										 |  |  |      * @param mixed $style | 
					
						
							|  |  |  |      * @return mixed | 
					
						
							| 
									
										
										
										
											2012-10-19 20:15:26 +04:00
										 |  |  |      * @throws GeneralException | 
					
						
							| 
									
										
										
										
											2010-03-13 23:33:46 +00:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											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; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2011-12-05 20:11:20 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-24 12:08:53 +00:00
										 |  |  |         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: | 
					
						
							| 
									
										
										
										
											2011-11-25 19:50:41 +04:00
										 |  |  |                 throw new GeneralException('Invalid fetch mode "' . $style . '" specified'); | 
					
						
							| 
									
										
										
										
											2010-02-24 12:08:53 +00:00
										 |  |  |         } | 
					
						
							|  |  |  |         return $row; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-12-05 20:11:20 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-24 12:08:53 +00:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param string $class | 
					
						
							| 
									
										
										
										
											2012-10-19 20:15:26 +04:00
										 |  |  |      * @return object | 
					
						
							| 
									
										
										
										
											2010-02-24 12:08:53 +00:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function fetchObject($class = 'stdClass') | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->result->fetch_object($class); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-11-15 19:19:30 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function fetchPairs() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $data = array(); | 
					
						
							|  |  |  |         while ($row = $this->fetch(Db::FETCH_NUM)) { | 
					
						
							|  |  |  |             $data[$row[0]] = $row[1]; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return $data; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-12-05 20:11:20 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-24 12:08:53 +00:00
										 |  |  |     public function close() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if ($this->result !== null) { | 
					
						
							|  |  |  |             $this->result->close(); | 
					
						
							|  |  |  |             $this->result = null; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-12-05 20:11:20 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-24 12:08:53 +00:00
										 |  |  |     public function affectedRows() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->driver->getConnection()->affected_rows; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-12-05 20:11:20 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-24 12:08:53 +00:00
										 |  |  |     public function numRows() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if ($this->result) { | 
					
						
							|  |  |  |             return $this->result->num_rows; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return false; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-12-05 20:11:20 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-19 15:26:00 +04:00
										 |  |  |     public function getMysqliResult() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->result; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:12 +04:00
										 |  |  |     protected function driverExecute($request) | 
					
						
							| 
									
										
										
										
											2010-02-24 12:08:53 +00:00
										 |  |  |     { | 
					
						
							|  |  |  |         /** | 
					
						
							|  |  |  |          * @var MySQLi | 
					
						
							|  |  |  |          */ | 
					
						
							|  |  |  |         $mysqli = $this->driver->getConnection(); | 
					
						
							| 
									
										
										
										
											2012-06-27 17:56:06 +04:00
										 |  |  |         if (Config::get('PROFILER_DETAILS')) { | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:12 +04:00
										 |  |  |             $profiler = Profiler::getInstance()->profilerCommand('MySQL', $request); | 
					
						
							|  |  |  |             $result = $mysqli->query($request); | 
					
						
							| 
									
										
										
										
											2010-03-13 23:33:46 +00:00
										 |  |  |             $profiler->end(); | 
					
						
							|  |  |  |         } else { | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:12 +04:00
										 |  |  |             $result = $mysqli->query($request); | 
					
						
							| 
									
										
										
										
											2010-03-13 23:33:46 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2010-02-24 12:08:53 +00:00
										 |  |  |         if ($result === false) { | 
					
						
							| 
									
										
										
										
											2011-11-15 16:55:12 +04:00
										 |  |  |             $message = $mysqli->error . "\nQuery: \"" . $request . '"'; | 
					
						
							| 
									
										
										
										
											2011-11-25 19:50:41 +04:00
										 |  |  |             throw new GeneralException($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
										 |  |  | } |