Файл: onlinepoisk.wm-scripts.ru/vendor/AR/lib/adapters/MysqlAdapter.php
Строк: 57
<?php
/**
 * @package ActiveRecord
 */
namespace ActiveRecord;
/**
 * Adapter for MySQL.
 *
 * @package ActiveRecord
 */
class MysqlAdapter extends Connection
{
    static $DEFAULT_PORT = 3306;
    public function limit($sql, $offset, $limit)
    {
        $offset = intval($offset);
        $limit = intval($limit);
        return "$sql LIMIT $offset,$limit";
    }
    public function query_column_info($table)
    {
        return $this->query("SHOW COLUMNS FROM $table");
    }
    public function query_for_tables()
    {
        return $this->query('SHOW TABLES');
    }
    public function create_column(&$column)
    {
        $c = new Column();
        $c->inflected_name    = Inflector::instance()->variablize($column['field']);
        $c->name            = $column['field'];
        $c->nullable        = ($column['null'] === 'YES' ? true : false);
        $c->pk                = ($column['key'] === 'PRI' ? true : false);
        $c->auto_increment    = ($column['extra'] === 'auto_increment' ? true : false);
        if ($column['type'] == 'timestamp' || $column['type'] == 'datetime')
        {
            $c->raw_type = 'datetime';
            $c->length = 19;
        }
        elseif ($column['type'] == 'date')
        {
            $c->raw_type = 'date';
            $c->length = 10;
        }
        elseif ($column['type'] == 'time')
        {
            $c->raw_type = 'time';
            $c->length = 8;
        }
        else
        {
            preg_match('/^([A-Za-z0-9_]+)((([0-9]+(,[0-9]+)?)))?/',$column['type'],$matches);
            $c->raw_type = (count($matches) > 0 ? $matches[1] : $column['type']);
            if (count($matches) >= 4)
                $c->length = intval($matches[3]);
        }
        $c->map_raw_type();
        $c->default = $c->cast($column['default'],$this);
        return $c;
    }
}
?>