diff options
author | Stan Hu <stanhu@gmail.com> | 2017-09-19 17:11:59 +0000 |
---|---|---|
committer | Stan Hu <stanhu@gmail.com> | 2017-09-19 17:11:59 +0000 |
commit | e5b0f2167d341954c72ba885ab3154b158b322a5 (patch) | |
tree | 7cc7bee93e9d4af3a3d959dfec6f5545675f8378 /db/migrate | |
parent | 343301bc86e8b07ff9b6f485871aac7bb3bc6339 (diff) | |
parent | 05a8f401c20e2a0b35360544aba12905239cc369 (diff) | |
download | gitlab-ce-e5b0f2167d341954c72ba885ab3154b158b322a5.tar.gz |
Merge branch 'reoganize-deployment-indexes' into 'master'
Reorganize indexes for the "deployments" table
Closes #36877
See merge request gitlab-org/gitlab-ce!14348
Diffstat (limited to 'db/migrate')
-rw-r--r-- | db/migrate/20170918222253_reorganize_deployments_indexes.rb | 28 | ||||
-rw-r--r-- | db/migrate/20170918223303_add_deployments_index_for_last_deployment.rb | 21 |
2 files changed, 49 insertions, 0 deletions
diff --git a/db/migrate/20170918222253_reorganize_deployments_indexes.rb b/db/migrate/20170918222253_reorganize_deployments_indexes.rb new file mode 100644 index 00000000000..139427ed2b9 --- /dev/null +++ b/db/migrate/20170918222253_reorganize_deployments_indexes.rb @@ -0,0 +1,28 @@ +# See http://doc.gitlab.com/ce/development/migration_style_guide.html +# for more information on how to write migrations for GitLab. + +class ReorganizeDeploymentsIndexes < ActiveRecord::Migration + include Gitlab::Database::MigrationHelpers + + DOWNTIME = false + + disable_ddl_transaction! + + def up + add_index_if_not_exists :deployments, [:environment_id, :iid, :project_id] + remove_index_if_exists :deployments, [:project_id, :environment_id, :iid] + end + + def down + add_index_if_not_exists :deployments, [:project_id, :environment_id, :iid] + remove_index_if_exists :deployments, [:environment_id, :iid, :project_id] + end + + def add_index_if_not_exists(table, columns) + add_concurrent_index(table, columns) unless index_exists?(table, columns) + end + + def remove_index_if_exists(table, columns) + remove_concurrent_index(table, columns) if index_exists?(table, columns) + end +end diff --git a/db/migrate/20170918223303_add_deployments_index_for_last_deployment.rb b/db/migrate/20170918223303_add_deployments_index_for_last_deployment.rb new file mode 100644 index 00000000000..b91efb86d98 --- /dev/null +++ b/db/migrate/20170918223303_add_deployments_index_for_last_deployment.rb @@ -0,0 +1,21 @@ +# See http://doc.gitlab.com/ce/development/migration_style_guide.html +# for more information on how to write migrations for GitLab. + +class AddDeploymentsIndexForLastDeployment < ActiveRecord::Migration + include Gitlab::Database::MigrationHelpers + + # Set this constant to true if this migration requires downtime. + DOWNTIME = false + + disable_ddl_transaction! + + TO_INDEX = [:deployments, %i[environment_id id]].freeze + + def up + add_concurrent_index(*TO_INDEX) + end + + def down + remove_concurrent_index(*TO_INDEX) + end +end |