module ActiveRecord module ConnectionAdapters module MySQL module ColumnMethods def primary_key(name, type = :primary_key, **options) options[:auto_increment] = true if [:integer, :bigint].include?(type) && !options.key?(:default) super end def blob(*args, **options) args.each { |name| column(name, :blob, options) } end def tinyblob(*args, **options) args.each { |name| column(name, :tinyblob, options) } end def mediumblob(*args, **options) args.each { |name| column(name, :mediumblob, options) } end def longblob(*args, **options) args.each { |name| column(name, :longblob, options) } end def tinytext(*args, **options) args.each { |name| column(name, :tinytext, options) } end def mediumtext(*args, **options) args.each { |name| column(name, :mediumtext, options) } end def longtext(*args, **options) args.each { |name| column(name, :longtext, options) } end def json(*args, **options) args.each { |name| column(name, :json, options) } end def unsigned_integer(*args, **options) args.each { |name| column(name, :unsigned_integer, options) } end def unsigned_bigint(*args, **options) args.each { |name| column(name, :unsigned_bigint, options) } end def unsigned_float(*args, **options) args.each { |name| column(name, :unsigned_float, options) } end def unsigned_decimal(*args, **options) args.each { |name| column(name, :unsigned_decimal, options) } end end class TableDefinition < ActiveRecord::ConnectionAdapters::TableDefinition include ColumnMethods def new_column_definition(name, type, **options) # :nodoc: case type when :virtual type = options[:type] when :primary_key type = :integer options[:limit] ||= 8 options[:auto_increment] = true options[:primary_key] = true when /\Aunsigned_(?.+)\z/ type = $~[:type].to_sym options[:unsigned] = true end super end private def aliased_types(name, fallback) fallback end end class Table < ActiveRecord::ConnectionAdapters::Table include ColumnMethods end end end end