Sha256: 44b6866945c6ec4c809a7771cf9660af5dff95c0f4bc30d77768367a295d4859
Contents?: true
Size: 1.38 KB
Versions: 3
Compression:
Stored size: 1.38 KB
Contents
class Baza::Driver::Mysql::Sql::Column DATA_SQL_ALLOWED_KEYS = [:type, :maxlength, :name, :primarykey, :autoincr, :default, :comment, :after, :first, :storage, :null, :renames].freeze attr_reader :data def initialize(data) @data = data end def sql data.each_key do |key| raise "Invalid key: '#{key}' (#{key.class.name})." unless DATA_SQL_ALLOWED_KEYS.include?(key) end raise "No type given." unless data[:type] type = data[:type].to_sym data[:maxlength] = 255 if type == :varchar && data[:maxlength].to_s.strip.empty? sql = "#{Baza::Driver::Mysql.quote_column(data.fetch(:name))} #{type}" sql << "(#{data[:maxlength]})" if data[:maxlength] sql << " PRIMARY KEY" if data[:primarykey] sql << " AUTO_INCREMENT" if data[:autoincr] sql << " NOT NULL" if data.key?(:null) && !data[:null] if data.key?(:default_func) sql << " DEFAULT #{data[:default_func]}" elsif data.key?(:default) && !data[:default].nil? sql << " DEFAULT #{Baza::Driver::Mysql.quote_value(data.fetch(:default))}" end sql << " COMMENT #{Baza::Driver::Mysql.quote_value(data.fetch(:comment))}" if data.key?(:comment) sql << " AFTER #{Baza::Driver::Mysql.quote_column(data.fetch(:after))}" if data[:after] && !data[:first] sql << " FIRST" if data[:first] sql << " STORAGE #{data[:storage].to_s.upcase}" if data[:storage] [sql] end end
Version data entries
3 entries across 3 versions & 1 rubygems
Version | Path |
---|---|
baza-0.0.38 | lib/baza/driver/mysql/sql/column.rb |
baza-0.0.37 | lib/baza/driver/mysql/sql/column.rb |
baza-0.0.36 | lib/baza/driver/mysql/sql/column.rb |