Вход Регистрация
Файл: l2.freedom.keo.su/inc/mysql.php
Строк: 70
<?
///////////////класс зля работы с бд//////////////////
class mysql
{
    var 
$db_id false;
    var 
$connected false;
    var 
$query_num 0;
    var 
$query_list = array();
    var 
$mysql_error '';
    var 
$mysql_version '';
    var 
$mysql_error_num 0;
    var 
$mysql_extend "MySQL";
    var 
$MySQL_time_taken 0;
    var 
$query_id false;
    
    
    function 
query($query$show_error=true)
    {
        
$time_before $this->get_real_time();

        
        if(!(
$this->query_id mysql_query($query) )) {

            
$this->mysql_error mysql_error();
            
$this->mysql_error_num mysql_errno();

            if(
$show_error) {
                
$this->display_error($this->mysql_error$this->mysql_error_num$query);
            }
        }
            
        
$this->MySQL_time_taken += $this->get_real_time() - $time_before;
        

            
$this->query_list[] = array( 'time'  => ($this->get_real_time() - $time_before), 
                                         
'query' => $query,
                                         
'num'   => (count($this->query_list) + 1));

        
$this->query_num ++;

        return 
$this->query_id;
    }
    
    function 
fetch_assoc($query_id '')
    {
        if (
$query_id == ''$query_id $this->query_id;

        return 
mysql_fetch_assoc($query_id);
    }

    function 
fetch_array($query_id '')
    {
        if (
$query_id == ''$query_id $this->query_id;

        return 
mysql_fetch_array($query_id);
    }
    
    
    function 
super_query($query$multi false)
    {

        if(!
$multi) {

            
$this->query($query);
            
$data $this->fetch_assoc();
            
$this->free();            
            return 
$data;

        } else {
            
$this->query($query);
            
            
$rows = array();
            while(
$row $this->fetch_assoc()) {
                
$rows[] = $row;
            }

            
$this->free();            

            return 
$rows;
        }
    }
    
    function 
num_rows($query_id '')
    {

        if (
$query_id == ''$query_id $this->query_id;

        return 
mysql_num_rows($query_id);
    }
    
    function 
insert_id()
    {
        return 
mysql_insert_id($this->db_id);
    }

    function 
get_result_fields($query_id '') {

        if (
$query_id == ''$query_id $this->query_id;

        while (
$field mysql_fetch_field($query_id))
        {
            
$fields[] = $field;
        }
        
        return 
$fields;
       }

    function 
safesql$source )
    {
        if (
$this->db_id) return mysql_real_escape_string ($source$this->db_id);
        else return 
mysql_escape_string($source);
    }

    function 
free$query_id '' )
    {

        if (
$query_id == ''$query_id $this->query_id;

        @
mysql_free_result($query_id);
    }

    function 
close()
    {
        @
mysql_close($this->db_id);
    }

    function 
get_real_time()
    {
        list(
$seconds$microSeconds) = explode(' 'microtime());
        return ((float)
$seconds + (float)$microSeconds);
    }    

    function 
display_error($error$error_num$query '')
    {
        if(
$query) {
            
// Safify query
            
$query preg_replace("/([0-9a-f]){32}/""********************************"$query); // Hides all hashes
            
$query_str "$query";
        }

        
$query htmlspecialchars($queryENT_QUOTES'ISO-8859-1');
        
$error htmlspecialchars($errorENT_QUOTES'ISO-8859-1');

        
$trace debug_backtrace();

        
$level 0;
        if (
$trace[1]['function'] == "query" $level 1;
        if (
$trace[2]['function'] == "super_query" $level 2;

        
$trace[$level]['file'] = str_replace(""""$trace[$level]['file']);

        echo 
'
        <div class="top" >MySQL Error!</div>
        <div class="box" ><b>MySQL error</b> in file: <b>'
.$trace[$level]['file'].'</b> at line <b>'.$trace[$level]['line'].'</b></div>
        <div class="box" >Error Number: <b>'
.$error_num.'</b></div>
        <div class="box" >The Error returned was:<br /> <b>'
.$error.'</b></div>
        <div class="box" ><b>SQL query:</b><br /><br />'
.$query.'</div>
        </div>'
;

        
    }

}


?>
Онлайн: 2
Реклама