Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
c29f56e1
Commit
c29f56e1
authored
Jul 14, 2020
by
Yannis Roussos
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add info on using reset_column_information to the Data Migration Guide
parent
ce855ed0
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
23 additions
and
6 deletions
+23
-6
doc/development/migration_style_guide.md
doc/development/migration_style_guide.md
+23
-6
No files found.
doc/development/migration_style_guide.md
View file @
c29f56e1
...
@@ -88,7 +88,7 @@ body:
...
@@ -88,7 +88,7 @@ body:
For example:
For example:
```
ruby
```
ruby
class
MyMigration
<
ActiveRecord
::
Migration
[
4.2
]
class
MyMigration
<
ActiveRecord
::
Migration
[
6.0
]
DOWNTIME
=
true
DOWNTIME
=
true
DOWNTIME_REASON
=
'This migration requires downtime because ...'
DOWNTIME_REASON
=
'This migration requires downtime because ...'
...
@@ -411,7 +411,7 @@ migration. For this to work your migration needs to include the module
...
@@ -411,7 +411,7 @@ migration. For this to work your migration needs to include the module
`Gitlab::Database::MultiThreadedMigration`
:
`Gitlab::Database::MultiThreadedMigration`
:
```
ruby
```
ruby
class
MyMigration
<
ActiveRecord
::
Migration
[
4.2
]
class
MyMigration
<
ActiveRecord
::
Migration
[
6.0
]
include
Gitlab
::
Database
::
MigrationHelpers
include
Gitlab
::
Database
::
MigrationHelpers
include
Gitlab
::
Database
::
MultiThreadedMigration
include
Gitlab
::
Database
::
MultiThreadedMigration
end
end
...
@@ -421,7 +421,7 @@ You can then use the method `with_multiple_threads` to perform work in separate
...
@@ -421,7 +421,7 @@ You can then use the method `with_multiple_threads` to perform work in separate
threads. For example:
threads. For example:
```
ruby
```
ruby
class
MyMigration
<
ActiveRecord
::
Migration
[
4.2
]
class
MyMigration
<
ActiveRecord
::
Migration
[
6.0
]
include
Gitlab
::
Database
::
MigrationHelpers
include
Gitlab
::
Database
::
MigrationHelpers
include
Gitlab
::
Database
::
MultiThreadedMigration
include
Gitlab
::
Database
::
MultiThreadedMigration
...
@@ -455,7 +455,7 @@ by calling the method `disable_ddl_transaction!` in the body of your migration
...
@@ -455,7 +455,7 @@ by calling the method `disable_ddl_transaction!` in the body of your migration
class like so:
class like so:
```
ruby
```
ruby
class
MyMigration
<
ActiveRecord
::
Migration
[
4.2
]
class
MyMigration
<
ActiveRecord
::
Migration
[
6.0
]
include
Gitlab
::
Database
::
MigrationHelpers
include
Gitlab
::
Database
::
MigrationHelpers
disable_ddl_transaction!
disable_ddl_transaction!
...
@@ -536,7 +536,7 @@ Here's an example where we add a new column with a foreign key
...
@@ -536,7 +536,7 @@ Here's an example where we add a new column with a foreign key
constraint. Note it includes
`index: true`
to create an index for it.
constraint. Note it includes
`index: true`
to create an index for it.
```
ruby
```
ruby
class
Migration
<
ActiveRecord
::
Migration
[
4.2
]
class
Migration
<
ActiveRecord
::
Migration
[
6.0
]
def
change
def
change
add_reference
:model
,
:other_model
,
index:
true
,
foreign_key:
{
on_delete: :cascade
}
add_reference
:model
,
:other_model
,
index:
true
,
foreign_key:
{
on_delete: :cascade
}
...
@@ -855,16 +855,33 @@ If you need more complex logic, you can define and use models local to a
...
@@ -855,16 +855,33 @@ If you need more complex logic, you can define and use models local to a
migration. For example:
migration. For example:
```
ruby
```
ruby
class
MyMigration
<
ActiveRecord
::
Migration
[
4.2
]
class
MyMigration
<
ActiveRecord
::
Migration
[
6.0
]
class
Project
<
ActiveRecord
::
Base
class
Project
<
ActiveRecord
::
Base
self
.
table_name
=
'projects'
self
.
table_name
=
'projects'
end
end
def
up
# Reset the column information of all the models that update the database
# to ensure the Active Record's knowledge of the table structure is current
Project
.
reset_column_information
# ... ...
end
end
end
```
```
When doing so be sure to explicitly set the model's table name, so it's not
When doing so be sure to explicitly set the model's table name, so it's not
derived from the class name or namespace.
derived from the class name or namespace.
Finally, make sure that
`reset_column_information`
is run in the
`up`
method of
the migration for all local Models that update the database.
The reason for that is that all migration classes are loaded at the beginning
(when
`db:migrate`
starts), so they can get out of sync with the table schema
they map to in case another migration updates that schema. That makes the data
migration fail when trying to insert or make updates to the underlying table,
as the new columns are reported as
`unknown attribute`
by
`ActiveRecord`
.
### Renaming reserved paths
### Renaming reserved paths
When a new route for projects is introduced, it could conflict with any
When a new route for projects is introduced, it could conflict with any
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment