I'm currently working on a dev branch and I will need to merge it to master one day. I have up to 20 migrations files on my dev branch and about the same number on master at the moment. I needed to make migrations on both branches which will result in migrations having the same prefix,
(ex 0003_auto
)
In other words, if you have migrations files generated by makemigrations
with the same prefix, what is the best/secure way of handling this.
Here are two ways I have figured myself (maybe entirely wrong):
Deleting all migrations files, merge the code and then running a fresh makemigrations
and migrate
which will result in only one migration file.
Using the --merge
flag to let django make the merge:
makemigrations --merge
Now, knowing all this I'd like to know what is the best way of handling this. In general, what should I use that will correctly merge conflicts and get me a fresh version of my project with every model updates.
EDIT
I think providing a step by step solution would be ideal for me and future users since there exists tons of informations on the subject but not one seems to be concise and clear.
From the Django docs:
Because migrations are stored in version control, you’ll occasionally come across situations where you and another developer have both committed a migration to the same app at the same time, resulting in two migrations with the same number.
Don’t worry - the numbers are just there for developers’ reference, Django just cares that each migration has a different name [emphasis added].
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With