103 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			103 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?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
 | |
| {
 | |
|     
 | |
|     /**
 | |
|      * Fetches single row
 | |
|      * 
 | |
|      * @param mixed $style
 | |
|      * @return mixed
 | |
|      */
 | |
|     public function fetch($style = Db::FETCH_OBJ)
 | |
|     {
 | |
|         if (!$this->result) {
 | |
|             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();
 | |
|         if (DEBUG) {
 | |
|             $profiler = Profiler::getInstance()->profilerCommand('MySQL', $sql);
 | |
|             $result = $mysqli->query($sql);
 | |
|             $profiler->end();
 | |
|         } else {
 | |
|             $result = $mysqli->query($sql);
 | |
|         }
 | |
|         if ($result === false) {
 | |
|             $message = $mysqli->error . "\nQuery: \"" . $sql . '"';
 | |
|             throw new Exception($message, $mysqli->errno);
 | |
|         }
 | |
|         if ($result instanceof MySQLi_Result) {
 | |
|             $this->result = $result;
 | |
|         }
 | |
|         return true;
 | |
|     }
 | |
| }
 |