Вход Регистрация
Файл: sys/plugins/classes/sql_parser.class.php
Строк: 45
<?php

/**
 * Парсинг SQL
 */
abstract class sql_parser {

    
/**
     * Выполняет запросы из SQL файла
     * @param string $file путь к sql файлу
     * @return int кол-во выполненых запросов
     */
    
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 файла
     * @param string $file путь к sql файлу
     * @return array
     */
    
static public function getQueriesFromFile($file) {
        return 
self::getQueries(file_get_contents($file));
    }

    
/**
     * Получение списка запросов из SQL строки
     * @param string $sql SQL запросы
     * @return array
     */
    
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$position3) !== '-- ') {
                        
$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;
    }

}
Онлайн: 1
Реклама