Файл: system/database.php
Строк: 63
<?php
/**
* Author: Elime;
* ICQ: 618878;
* E-mail: elime4@gmail.com;
*/
class MySQL
{
public $db_link;
public $debugging = true;
public $list_queries = array();
public $count_queries = 0;
public $time_queries = 0;
/* Соединение с базой */
public function connect()
{
$this->db_link = mysqli_connect(DB_HOST,DB_USER,DB_PASS,DB_BASE) or $this->error('Не возможно подключиться к MySQL серверу');
if (mysqli_connect_errno())
{
echo "Возникла ошибка БД: " . mysqli_connect_error();
}
}
/* Выполнение запроса к базе */
public function query($query)
{
/* Засекаем время выполнения запроса */
$start_time = microtime(1);
/* Выполняем запрос */
$result = mysqli_query($this->db_link, $query) or $this->error($query . PHP_EOL . mysqli_error($this->db_link));
/* Получаем время по окончанию запроса */
$end_time = microtime(1);
/* Высчитываем время на запрос */
$query_time = $end_time - $start_time;
/* Массив запросов и время выполнения каждого */
$this->list_queries[] = array('query' => $query, 'time' => $query_time);
/* Общее время выполнения запросов и количество запросов */
$this->time_queries += $query_time;
$this->count_queries++;
return $result;
}
/* Массив запросов */
public function list_queries()
{
return $this->list_queries;
}
/* Кодировка БД */
public function charset($charset)
{
mysqli_set_charset($this->db_link,"utf8");;
}
/* Получение результата */
public function result($query)
{
$query = $this->query($query);
return mysqli_fetch_row($query)[0];
}
/* Последний вставленный id */
public function insert_id()
{
return mysqli_insert_id($this->db_link);
}
/* Аналог mysql_fetch_assoc() */
public function fetch($result)
{
return mysqli_fetch_assoc($result);
}
/* Получение строки */
public function get_row($query, $restype = MYSQL_ASSOC)
{
$result = $this->query($query);
if($row = mysqli_fetch_array($result, $restype))
{
return array_map('stripslashes', $row);
}
else
{
return false;
}
}
/* Аналог mysql_num_rows() */
public function num($result)
{
$return = mysqli_num_rows($result);
return count($return);
}
public function real($str) {
return mysqli_real_escape_string($this->db_link, $str);
}
/* Вывод ошибки и завершение работы */
protected function error($error)
{
if($this->debugging) echo '<pre>'. $error .'</pre>';
exit;
}
}
?>