Opened 10 years ago
Last modified 2 years ago
#24363 new New feature
Combine ALTER TABLE .. MODIFY statements for multiple columns into one statement.
Reported by: | slachinger | Owned by: | nobody |
---|---|---|---|
Component: | Migrations | Version: | 1.7 |
Severity: | Normal | Keywords: | Modify Field Column |
Cc: | simon.lachinger@…, emorley@…, Phil Krylov, Adam Johnson, elonzh | Triage Stage: | Someday/Maybe |
Has patch: | no | Needs documentation: | no |
Needs tests: | no | Patch needs improvement: | no |
Easy pickings: | no | UI/UX: | no |
Description
If a migration modifies multiple columns of a table for each column/field an ALTER TABLE statement is executed. However most DBMS (all but sqlite?) support modification of several columns at once.
For example, the consider this migration:
class Migration(migrations.Migration): dependencies = [ ('core', '0001_initial'), ] operations = [ migrations.AlterField( model_name='employee', name='salary', field=models.BigIntegerField(), preserve_default=True, ), migrations.AlterField( model_name='employee', name='academic_degrees', field=models.CharField(max_length=200), preserve_default=True, ), ]
This currently results in two ALTER TABLE statments being executed:
ALTER TABLE employee MODIFY COLUMN salary bigint; ALTER TABLE employee MODIFY COLUMN academic_degrees varchar(200);
But this takes twice as long as using only one ALTER TABLE statement since the whole table is essentially recreated twice (at least in MySQL but IIRC it is the same in PG):
ALTER TABLE employee MODIFY COLUMN salary bigint, MODIFY COLUMN academic_degrees varchar(200);
This is particulary annoying because it essentially multiplies the time the migration runs by the number of modified fields and thus causes much longer downtimes of the service.
NOTE: this is most likely related to #24203 which refers to adding columns instead of modifying.
Change History (7)
comment:1 by , 10 years ago
Triage Stage: | Unreviewed → Someday/Maybe |
---|---|
Type: | Uncategorized → New feature |
comment:3 by , 8 years ago
Cc: | added |
---|
comment:4 by , 5 years ago
Cc: | added |
---|
comment:5 by , 5 years ago
Cc: | added |
---|
comment:6 by , 2 years ago
Cc: | added |
---|
comment:7 by , 2 years ago
Cc: | removed |
---|
comment:8 by , 2 years ago
Cc: | added |
---|
As I said in #24203, some performance numbers would be useful to assess the benefits of this versus the cost of additional code complexity.