Файл: sys/classes/sql_parser.class.php
Строк: 38
<?php
#Парсинг SQL
abstract class sql_parser {
#Выполняет запросы из SQL файла
static public function executeQueriesFromFile($file) {
$queries = self::getQueriesFromFile($file);
$count = 0;
foreach ($queries as $sql) {
#некоторые запросы могут выполняться долго, поэтому увеличиваем временной лимит.
if (function_exists('set_time_limit')) {
set_time_limit(600);
}
#подсчитываем только успешно выполненные запросы
if (DB::me()->query($sql)) {
$count++;
}
}
return $count;
}
#Получение списка запросов из SQL файла
static public function getQueriesFromFile($file) {
return self::getQueries(file_get_contents($file));
}
#Получение списка запросов из SQL строки
static public function getQueries($sql) {
$queries = array();
$strlen = strlen($sql);
$position = 0;
$query = '';
for (; $position < $strlen; ++$position) {
$char = $sql {
$position };
switch ($char) {
case '-':
if (substr($sql, $position, 3) !== '-- ') {
$query .= $char;
break;
}
case '#':
while ($char !== "r" && $char !== "n" && $position < $strlen - 1)
$char = $sql {
++$position };
break;
case '`':
case ''':
case '"':
$quote = $char;
$query .= $quote;
while ($position < $strlen - 1) {
$char = $sql {
++$position };
if ($char === '\') {
$query .= $char;
if ($position < $strlen - 1) {
$char = $sql {
++$position };
$query .= $char;
if ($position < $strlen - 1)
$char = $sql {
++$position };
} else {
break;
}
}
if ($char === $quote)
break;
$query .= $char;
}
$query .= $quote;
break;
case ';':
$query = trim($query);
if ($query)
$queries[] = $query;
$query = '';
break;
default:
$query .= $char;
break;
}
}
$query = trim($query);
if ($query) {
$queries[] = $query;
}
return $queries;
}
}