Reputation: 4673
As the title says, I can't seem to get migrations working.
The app was originally under 1.6, so I understand that migrations won't be there initially, and indeed if I run python manage.py migrate
I get:
Operations to perform:
Synchronize unmigrated apps: myapp
Apply all migrations: admin, contenttypes, auth, sessions
Synchronizing apps without migrations:
Creating tables...
Installing custom SQL...
Installing indexes...
Running migrations:
No migrations to apply.
If I make a change to any models in myapp
, it still says unmigrated, as expected.
But if I run python manage.py makemigrations myapp
I get:
No changes detected in app 'myapp'
Doesn't seem to matter what or how I run the command, it's never detecting the app as having changes, nor is it adding any migration files to the app.
Is there any way to force an app onto migrations and essentially say "This is my base to work with" or anything? Or am I missing something?
My database is a PostgreSQL one if that helps at all.
Upvotes: 155
Views: 152584
Reputation: 187
First make sure that your app is registered on
INSTALLED_APPS
of your project settings.py file. If your migrations don't apply to your project you can run
python manage.py makemigrations {app_name}
then apply to migrate the command
python manage.py migrate
or
python manage.py migrate {app_name}
if migrations are applied but migrate command is not applied, check your database, there will be a table called "django_migrations". Then check whether your newly added migrations file exists in this table or not. If exists remove this row and apply to migrate command again. Hope it will work.
Upvotes: 2
Reputation: 275
sometime/somehow you get into situation where django understands that migration is already applied and when you run migrations it will say "No changes detected" in this situation follow these steps:
delete the last migration from your migration table
delete from django_migrations where id =
run the migrations and it should work
django-admin manage.py makemigrations django-admin manage.py migrate
Upvotes: 0
Reputation: 47
for me i remove migrations files on env folder env\Lib\site-packages\django\contrib\auth\migrations\...
but keep the __init__.py
don't remove it
Upvotes: -1
Reputation: 91
Load ur app to settings.py and py .\manage.py makemigrations
INSTALLED_APPS = [ 'appname' ]
Upvotes: 0
Reputation: 4050
This may happen due to the following reasons:
INSTALLED_APPS
list in settings.py
(You have to add either the app name or the dotted path to the subclass of AppConfig in apps.py in the app folder, depending on the version of django you are using). Refer documentation: INSTALLED_APPSmigrations
folder inside those apps. (Solution: just create that folder).__init__.py
file inside migrations
folder of those apps. (Solution: Just create an empty file with name __init__.py
)__init__.py
file inside the app folder. (Solution: Just create an empty file with name __init__.py
)models.py
file in the appmodels.py
doesn't inherit django.db.models.Model
models.py
Note:
A common mistake is to add migrations
folder in .gitignore
file. When cloned from remote repo, migrations
folder and/or __init__.py
files will be missing in local repo. This causes problem.
Migration files are supposed to be included in the repo. read here. If your team frequently faces migration issues you may consider ignoring migration files as follows:
I suggest to gitignore migration files by adding the following lines to .gitignore
file
*/migrations/*
!*/migrations/__init__.py
Remember, it is not recommended to gitignore migration files as per django documentation
Upvotes: 88
Reputation: 1649
I had mistakely deleted folder of migrations
from my project directory.
Solution is to create __init__.py
file in the migrations
folder, and then,
python manage.py makemigrations
python manage.py migrate
Upvotes: 5
Reputation: 31
One of the cause may be You didn't register your models in admin.py file . First register your models in admin.py file then do the migrations.
Upvotes: 2
Reputation:
I have encountered this issue, the command
python manage.py makemigrations
worked with me once I saved the changes that I made on the files.
Upvotes: 0
Reputation: 429
In my case I needed to add my model to the _init_.py file of the models folder where my model was defined:
from myapp.models.mymodel import MyModel
Upvotes: 3
Reputation: 5
Upvotes: 1
Reputation: 5
python manage.py makemigrations accounts Migrations for 'accounts': accounts\migrations\0001_initial.py - Create model Customer - Create model Tag - Create model Product - Create model Order
Note: here "accounts" is my app name
Upvotes: -1
Reputation: 71
First this solution is applicable to those who are facing the same issue during deployment on heroku server, I was facing same issue.
To deploy, there is a mandatory step which is to add django_heroku.settings(locals()) in settings.py file.
Changes: When I changed the above line to django_heroku.settings(locals(), databases=False), it worked flawlessly.
Upvotes: 0
Reputation: 1679
You may need to fake the initial migrations using the command below
python manage.py migrate --fake-initial
Upvotes: 1
Reputation: 37
Had the same problem Make sure whatever classes you have defined in models.py, you must have to inherit models.Model class.
class Product(models.Model):
title = models.TextField()
description = models.TextField()
price = models.TextField()
Upvotes: 2
Reputation: 643
Maybe I am too late but did you try to have a migrations
folder in your app with a __init__.py
file in it?
Upvotes: 11
Reputation: 518
Added this answer because none of other available above worked for me.
In my case something even more weird was happening (Django 1.7 Version), In my models.py I had an "extra" line at the end of my file (it was a blank line) and when I executed the python manage.py makemigrations
command the result was: "no changes detected".
To fix this I deleted this "blank line" that was at the end of my models.py file and I did run the command again, everything was fixed and all the changes made to models.py were detected!
Upvotes: 0
Reputation: 2204
This is kind of a stupid mistake to make, but having an extra comma at the end of the field declaration line in the model class, makes the line have no effect.
It happens when you copy paste the def. from the migration, which itself is defined as an array.
Though maybe this would help someone :-)
Upvotes: 13
Reputation: 745
Adding my 2c, since none of these solutions worked for me, but this did...
I had just run manage.py squashmigrations
and removed the old migrations (both the files and lines in the the django.migrations database table).
This left a line like this in the last migration file:
replaces = [(b'my_app', '0006_auto_20170713_1735'), (b'my_app', '0007_auto_20170713_2003'), (b'my_app', '0008_auto_20170713_2004')]
This apparently confused Django and caused weird behavior: running manage.py makemigrations my_app
would recreate the initial migration as if none existed. Removing the replaces...
line fixed the problem!
Upvotes: -1
Reputation: 875
./manage makemigrations
./manage migrate
Migrations track changes to DB so if youre changing from unmanaged to managed, you'll need to make sure that youre database table is up to date relating to the Model you're dealing with.
If you are still in dev mode, I personally decided to delete the migration files in my IDE as well as in the django_migrations table relating to my Model and rerun the above command.
REMEMBER: if you have a migration that ends with _001 in your IDE & _003 in your database. Django will only see if you have a migration ending with _004 for anything to update.
The 2 (code & db migrations) are linked and work in tandem.
Happy coding.
Upvotes: 1
Reputation: 2526
Maybe this will help someone.
I've deleted my models.py
and expected makemigrations
to create DeleteModel
statements.
Remember to delete *.pyc
files!
Upvotes: 1
Reputation: 2970
Maybe that can help someone, I had the same problem.
I've already created two tables with the serializer class and the views. So when I wanted to updated, I had this error.
I followed this steps:
.\manage.py makemigrations app
.\manage.py migrate
models.py
1
and 2
.models.py
5
.If you're working with Pycharm, local history is very helpfull.
Upvotes: 1
Reputation: 21
I recently upgraded Django from 1.6 to 1.8 and had few apps and migrations for them. I used south and schemamigrations
for creating migrations in Django 1.6, which is dropped in Django 1.8.
When I added new models after upgrade, the makemigrations
command wasn't detecting any changes. And then I tried the solution suggested by @drojf (1st answer), it worked fine, but failed to apply fake initial migration (python manage.py --fake-initial
). I was doing this as my tables (old tables) were already created.
Finally this worked for me, removed new models (or model changes) from models.py and then had to delete (or rename for safety backup) migrations folder of all apps and run python manage.py
makemigrations for all apps, then did python manage.py migrate --fake-initial
. This worked like a charm. Once initial migration is created for all apps and fake initial migrated, then added new models and followed regular process of makemigrations
and migrate on that app. The changes were detected now and everything went fine.
I just thought of sharing it here, if someone faces same problem (having schemamigrations
of south for their apps), it might help them :)
Upvotes: 1
Reputation: 19997
Make sure your model is not abstract
. I actually made that mistake and it took a while, so I thought I'd post it.
Upvotes: 5
Reputation: 664
Following worked for me:
Worked for me: Python 3.4, Django 1.10
Upvotes: 7
Reputation: 1351
Adding this answer because only this method helped me.
I deleted the migrations
folder run makemigrations
and migrate
.
It still said: No migrations to apply.
I went to migrate
folder and opened the last created file,
comment the migration I wanted(It was detected and entered there)
and run migrate
again.
This basically editing the migrations file manually.
Do this only if you understand the file content.
Upvotes: 5
Reputation: 306
Agree with @furins. If everything seems to be in order and yet this problem arises, checkout if there is any property method with same title as the attribute which you are trying to add in the Model class.
Upvotes: 16
Reputation: 1609
People like me who don't like migrations can use steps below.
python manage.py makemigrations app_label
for the initial migration.python manage.py migrate
for creating tables before you make changes.If you confused any of these steps, read the migration files. Change them to correct your schema or remove unwanted files but don't forget to change next migration file's dependencies part ;)
I hope this will help someone in future.
Upvotes: 6
Reputation: 5048
Just in case you have a specific field that does not get identified by makemigrations: check twice if you have a property with the same name.
example:
field = django.db.models.CharField(max_length=10, default = '', blank=True, null=True)
# ... later
@property
def field(self):
pass
the property will "overwrite" the field definition so changes will not get identified by makemigrations
Upvotes: 5
Reputation: 383
The answer is on this stackoverflow post, by cdvv7788 Migrations in Django 1.7
If it is the first time you are migrating that app you have to use:
manage.py makemigrations myappname Once you do that you can do:
manage.py migrate If you had your app in database, modified its model and its not updating the changes on makemigrations you probably havent migrated it yet. Change your model back to its original form, run the first command (with the app name) and migrate...it will fake it. Once you do that put back the changes on your model, run makemigrations and migrate again and it should work.
I was having the exact same trouble and doing the above worked perfectly.
I had moved my django app to cloud9 and for some reason I never caught the initial migration.
Upvotes: 7
Reputation: 3959
You want to check the settings.py
in the INSTALLED_APPS
list and make sure all the apps with models are listed in there.
Running makemigrations
in the project folder means it will look to update all the tables related to all the apps included in settings.py
for the project. Once you include it, makemigrations
will automatically include the app (this saves a lot of work so you don't have to run makemigrations app_name
for every app in your project/site).
Upvotes: 5