From 59fb2eec8c80c27366bdcbd2b34f3ec3168eebf0 Mon Sep 17 00:00:00 2001 From: Koichi ITO Date: Fri, 3 Dec 2021 01:43:03 +0900 Subject: [PATCH] Add `if_exists` option to `remove_index` Follow up to https://github.com/rails/rails/pull/38967. The `if_exists` option has been introduced since Rails 6.1. --- .../connection_adapters/oracle_enhanced/schema_statements.rb | 2 ++ 1 file changed, 2 insertions(+) diff --git a/lib/active_record/connection_adapters/oracle_enhanced/schema_statements.rb b/lib/active_record/connection_adapters/oracle_enhanced/schema_statements.rb index 49a842496..516ac371c 100644 --- a/lib/active_record/connection_adapters/oracle_enhanced/schema_statements.rb +++ b/lib/active_record/connection_adapters/oracle_enhanced/schema_statements.rb @@ -330,6 +330,8 @@ def add_index_options(table_name, column_name, comment: nil, **options) # :nodoc # Remove the given index from the table. # Gives warning if index does not exist def remove_index(table_name, column_name = nil, **options) # :nodoc: + return if options[:if_exists] && !index_exists?(table_name, column_name, **options) + index_name = index_name_for_remove(table_name, column_name, options) # TODO: It should execute only when index_type == "UNIQUE" execute "ALTER TABLE #{quote_table_name(table_name)} DROP CONSTRAINT #{quote_column_name(index_name)}" rescue nil