class ActiveRecord::ConnectionAdapters::PostgreSQL::SchemaDumper
:nodoc:
def default_primary_key?(column)
def default_primary_key?(column) schema_type(column) == :bigserial end
def explicit_primary_key_default?(column)
def explicit_primary_key_default?(column) column.type == :uuid || (column.type == :integer && !column.serial?) end
def extensions(stream)
def extensions(stream) extensions = @connection.extensions if extensions.any? stream.puts " # These are extensions that must be enabled in order to support this database" extensions.sort.each do |extension| stream.puts " enable_extension #{extension.inspect}" end stream.puts end end
def extract_expression_for_virtual_column(column)
def extract_expression_for_virtual_column(column) column.default_function.inspect end
def prepare_column_options(column)
def prepare_column_options(column) spec = super spec[:array] = "true" if column.array? if @connection.supports_virtual_columns? && column.virtual? spec[:as] = extract_expression_for_virtual_column(column) spec[:stored] = true spec = { type: schema_type(column).inspect }.merge!(spec) end spec[:enum_type] = "\"#{column.sql_type}\"" if column.enum? spec end
def schema_expression(column)
def schema_expression(column) super unless column.serial? end
def schema_type(column)
def schema_type(column) return super unless column.serial? if column.bigint? :bigserial else :serial end end
def types(stream)
def types(stream) types = @connection.enum_types if types.any? stream.puts " # Custom types defined in this database." stream.puts " # Note that some types may not work with other database engines. Be careful if changing database." types.sort.each do |name, values| stream.puts " create_enum #{name.inspect}, #{values.split(",").inspect}" end stream.puts end end