Method: ActiveRecord::ConnectionAdapters::PostgreSQL::SchemaStatements#remove_index
- Defined in:
- activerecord/lib/active_record/connection_adapters/postgresql/schema_statements.rb
#remove_index(table_name, column_name = nil, **options) ⇒ Object
:nodoc:
499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 |
# File 'activerecord/lib/active_record/connection_adapters/postgresql/schema_statements.rb', line 499 def remove_index(table_name, column_name = nil, **) # :nodoc: table = Utils.extract_schema_qualified_name(table_name.to_s) if .key?(:name) provided_index = Utils.extract_schema_qualified_name([:name].to_s) [:name] = provided_index.identifier table = PostgreSQL::Name.new(provided_index.schema, table.identifier) unless table.schema.present? if provided_index.schema.present? && table.schema != provided_index.schema raise ArgumentError.new("Index schema '#{provided_index.schema}' does not match table schema '#{table.schema}'") end end return if [:if_exists] && !index_exists?(table_name, column_name, **) index_to_remove = PostgreSQL::Name.new(table.schema, index_name_for_remove(table.to_s, column_name, )) execute "DROP INDEX #{index_algorithm(options[:algorithm])} #{quote_table_name(index_to_remove)}" end |