diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2022-10-24 12:11:03 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2022-10-24 12:11:03 +0300 |
commit | fda0e422a7804d541454d86b50113645d8d516f8 (patch) | |
tree | d9aa72a6190d689a424aab28fcfecc643baa48af /doc/development | |
parent | 4bb7b91adff0cc7e4e7417bf2fc50f9c5cf6e173 (diff) |
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'doc/development')
-rw-r--r-- | doc/development/database/adding_database_indexes.md | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/doc/development/database/adding_database_indexes.md b/doc/development/database/adding_database_indexes.md index 040c6780316..d4cd807ef22 100644 --- a/doc/development/database/adding_database_indexes.md +++ b/doc/development/database/adding_database_indexes.md @@ -215,6 +215,42 @@ def down end ``` +## Indexes for partitioned tables + +Indexes [cannot be created](https://www.postgresql.org/docs/15/ddl-partitioning.html#DDL-PARTITIONING-DECLARATIVE-MAINTENANCE) +**concurrently** on a partitioned table. You must use `CONCURRENTLY` to avoid service disruption in a hot system. + +To create an index on a partitioned table, use `add_concurrent_partitioned_index`, provided by the database team. + +Under the hood, `add_concurrent_partitioned_index`: + +1. Creates indexes on each partition using `CONCURRENTLY`. +1. Creates an index on the parent table. + +A Rails migration example: + +```ruby +# in db/post_migrate/ + +class AddIndexToPartitionedTable < Gitlab::Database::Migration[2.0] + include Gitlab::Database::PartitioningMigrationHelpers + + disable_ddl_transaction! + + TABLE_NAME = :table_name + COLUMN_NAMES = [:partition_id, :id] + INDEX_NAME = :index_name + + def up + add_concurrent_partitioned_index(TABLE_NAME, COLUMN_NAMES, name: INDEX_NAME) + end + + def down + remove_concurrent_partitioned_index_by_name(TABLE_NAME, INDEX_NAME) + end +end +``` + ## Create indexes asynchronously For very large tables, index creation can be a challenge to manage. |