postgreSQL Connector
git-svn-id: svn+ssh://code.netmonsters.ru/svn/majestic/trunk@76 4cb57b5f-5bbd-dd11-951b-001d605cbbc5
This commit is contained in:
		
							
								
								
									
										110
									
								
								classes/pg_DBConnector.class.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										110
									
								
								classes/pg_DBConnector.class.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,110 @@ | ||||
| <?php | ||||
| /** | ||||
|  * Класс базы данных. | ||||
|  * Возвращает идентификатор соединения | ||||
|  * | ||||
|  * @copyright | ||||
|  * @link | ||||
|  * @package Majestic | ||||
|  * @subpackage DB | ||||
|  * @since | ||||
|  * @version SVN: $Id$ | ||||
|  * @filesource $URL$ | ||||
|  */ | ||||
| class DBConnector | ||||
| { | ||||
|     static private $handlers = array(); | ||||
|     static public $queries   = array(); | ||||
|  | ||||
|     /** | ||||
|      * Запрещаем new и клонирование | ||||
|      */ | ||||
|     private function __construct(){} | ||||
|  | ||||
|     private function __clone(){} | ||||
|  | ||||
|     /** | ||||
|      * Получение соединения. | ||||
|      * Если соединение с такими параметрами уже есть - новое не создается. | ||||
|      * | ||||
|      * @param array $db_settings - массив настроек | ||||
|      * @return resource - идентификатор соединения | ||||
|      */ | ||||
|     static public function getConnect($db_settings) | ||||
|     { | ||||
|         $handler_name = self::getConnectionName($db_settings); | ||||
|  | ||||
|         if (isset(self::$handlers[$handler_name])) { | ||||
|             return self::$handlers[$handler_name]; | ||||
|         } | ||||
|  | ||||
|         if (!$handler = pg_connect("host='".$db_settings['host']."' dbname='".$db_settings['database']."' user='".$db_settings['user'].'" password="'.$db_settings['password']."'")) { | ||||
|             throw new MJException('Can\'t connect to DB '.pg_last_error($handler), 2); | ||||
|         } | ||||
|          | ||||
|         return self::$handlers[$handler_name] = $handler; | ||||
|     } | ||||
|  | ||||
|     static protected function getConnectionName($db_settings) | ||||
|     { | ||||
|         return $db_settings['host'] . '-' . $db_settings['database']; | ||||
|     } | ||||
|  | ||||
| ///////// | ||||
|  | ||||
|     static public function query($handler, $sql) | ||||
|     { | ||||
|         return pg_query($handler, $sql); | ||||
|     } | ||||
|  | ||||
|     static public function escape($handler, $str) | ||||
|     { | ||||
|         return pg_escape_string($str); | ||||
|     } | ||||
|  | ||||
|     static public function error($handler) | ||||
|     { | ||||
|         return pg_last_error($handler); | ||||
|     } | ||||
|  | ||||
|     static public function free($result) | ||||
|     { | ||||
|         return pg_free_result($result); | ||||
|     } | ||||
|  | ||||
|     static public function fetchObject($result, $class_name = false) | ||||
|     { | ||||
|         return $class_name ? pg_fetch_object($result, null, $class_name) : pg_fetch_object($result); | ||||
|     } | ||||
|  | ||||
|     static public function numRows($result) | ||||
|     { | ||||
|         return pg_num_rows($result); | ||||
|     } | ||||
|  | ||||
|     static public function affectedRows($handler) | ||||
|     { | ||||
|         return pg_affected_rows($handler); | ||||
|     } | ||||
|  | ||||
|     static public function getId($handler) | ||||
|     { | ||||
|         return pg_last_oid($handler); | ||||
|     } | ||||
|  | ||||
|     static public function autocommit($handler, $switch) | ||||
|     { | ||||
|         throw new MJException('Autocommit disabled for postgreSQL Connector' ,1); | ||||
|     } | ||||
|  | ||||
|     static public function commit($handler) | ||||
|     { | ||||
|         throw new MJException('Commit disabled for postgreSQL Connector' ,1); | ||||
|     } | ||||
|  | ||||
|     static public function rollback($handler) | ||||
|     { | ||||
|         throw new MJException('Rollback disabled for postgreSQL Connector' ,1); | ||||
|     } | ||||
| } | ||||
| ?> | ||||
		Reference in New Issue
	
	Block a user