40 lines
1.3 KiB
PHP
40 lines
1.3 KiB
PHP
![]() |
<?php
|
|||
|
/**
|
|||
|
* Класс базы данных.
|
|||
|
* Возвращает идентификатор соединения
|
|||
|
*
|
|||
|
*/
|
|||
|
class DBConnector
|
|||
|
{
|
|||
|
static private $handlers = array();
|
|||
|
static public $queries = array();
|
|||
|
|
|||
|
/**
|
|||
|
* Получение соединения.
|
|||
|
* Если соединение с такими параметрами уже есть - новое не создается.
|
|||
|
*
|
|||
|
* @param array $db_settings - массив настроек
|
|||
|
* @return resource - идентификатор соединения
|
|||
|
*/
|
|||
|
static function getConnect($db_settings)
|
|||
|
{
|
|||
|
$handler_name = self::getConnectionName($db_settings);
|
|||
|
|
|||
|
if (isset(self::$handlers[$handler_name])) {
|
|||
|
return self::$handlers[$handler_name];
|
|||
|
}
|
|||
|
|
|||
|
if (!$handler = @mysqli_connect($db_settings['host'], $db_settings['user'], $db_settings['password'], $db_settings['database'])) {
|
|||
|
throw new MJException('Can\'t connect to DB '.mysqli_connect_error(), 2);
|
|||
|
}
|
|||
|
|
|||
|
mysqli_query($handler, "SET NAMES 'utf8'"); //cheat!!!
|
|||
|
return self::$handlers[$handler_name] = $handler;
|
|||
|
}
|
|||
|
|
|||
|
static function getConnectionName($db_settings)
|
|||
|
{
|
|||
|
return $db_settings['host'].'-'.$db_settings['database'];
|
|||
|
}
|
|||
|
}
|
|||
|
?>
|