diff options
author | Valery Sizov <valery@gitlab.com> | 2019-08-06 17:08:28 +0300 |
---|---|---|
committer | Valery Sizov <valery@gitlab.com> | 2019-08-07 18:02:20 +0300 |
commit | 19f36a34521d9fb5921f3422b4ef6b3a412fa394 (patch) | |
tree | 15e254bd193d754bdc85d87e53db187c4cc2652d | |
parent | 4aa824e7059889c7b8badb4bd43cc44f9a01201f (diff) | |
download | gitlab-ce-migration-style-guide-docs.tar.gz |
Update Migration Style Guidemigration-style-guide-docs
-rw-r--r-- | doc/development/migration_style_guide.md | 11 |
1 files changed, 3 insertions, 8 deletions
diff --git a/doc/development/migration_style_guide.md b/doc/development/migration_style_guide.md index 0c7601b415e..3181b3a88cc 100644 --- a/doc/development/migration_style_guide.md +++ b/doc/development/migration_style_guide.md @@ -10,9 +10,7 @@ migrations are written carefully, can be applied online and adhere to the style guide below. Migrations are **not** allowed to require GitLab installations to be taken -offline unless _absolutely necessary_. Downtime assumptions should be based on -the behaviour of a migration when performed using PostgreSQL, as various -operations in MySQL may require downtime without there being alternatives. +offline unless _absolutely necessary_. When downtime is necessary the migration has to be approved by: @@ -343,10 +341,7 @@ class AddOptionsToBuildMetadata < ActiveRecord::Migration[5.0] end ``` -On MySQL the `JSON` and `JSONB` is translated to `TEXT 1MB`, as `JSONB` is PostgreSQL only feature. - -For above reason you have to use a serializer to provide a translation layer -in order to support PostgreSQL and MySQL seamlessly: +You have to use a serializer to provide a translation layer: ```ruby class BuildMetadata @@ -356,7 +351,7 @@ end ## Testing -Make sure that your migration works with MySQL and PostgreSQL with data. An +Make sure that your migration works for databases with data. An empty database does not guarantee that your migration is correct. Make sure your migration can be reversed. |