[Django]-How to reset db in Django? I get a command 'reset' not found error

189👍

reset has been replaced by flush with Django 1.5, see:

python manage.py help flush

42👍

It looks like the ‘flush’ answer will work for some, but not all cases. I needed not just to flush the values in the database, but to recreate the tables properly. I’m not using migrations yet (early days) so I really needed to drop all the tables.

Two ways I’ve found to drop all tables, both require something other than core django.

If you’re on Heroku, drop all the tables with pg:reset:

heroku pg:reset DATABASE_URL
heroku run python manage.py syncdb

If you can install Django Extensions, it has a way to do a complete reset:

python ./manage.py reset_db --router=default
👤LisaD

27👍

Similar to LisaD’s answer, Django Extensions has a great reset_db command that totally drops everything, instead of just truncating the tables like “flush” does.

python ./manage.py reset_db

Merely flushing the tables wasn’t fixing a persistent error that occurred when I was deleting objects. Doing a reset_db fixed the problem.

👤aendra

25👍

if you are using Django 2.0
Then

python manage.py flush 

will work

22👍

If you want to clean the whole database, you can use:

python manage.py flush

If you want to clean the database table of a Django app, you can use:

python manage.py migrate <app-name> zero

13👍

With django 1.11, simply delete all migration files from the migrations folder of each application (all files except __init__.py). Then

  1. Manually drop database.
  2. Manually create database.
  3. Run python3 manage.py makemigrations.
  4. Run python3 manage.py migrate.

And voilla, your database has been completely reset.

6👍

python manage.py flush

deleted old db contents,

Don’t forget to create new superuser:

python manage.py createsuperuser

4👍

For me this solved the problem.

heroku pg:reset DATABASE_URL

heroku run bash
>> Inside heroku bash
cd app_name && rm -rf migrations && cd ..
./manage.py makemigrations app_name
./manage.py migrate
👤yask

3👍

Just a follow up to @LisaD’s answer.
As of 2016 (Django 1.9), you need to type:

heroku pg:reset DATABASE_URL
heroku run python manage.py makemigrations
heroku run python manage.py migrate

This will give you a fresh new database within Heroku.

👤Jan

3👍

  1. Just manually delete you database. Ensure you create backup first (in my case db.sqlite3 is my database)

  2. Run this command manage.py migrate

👤bikram

0👍

I use python manage.py flush on django 4.1 with postreSQL

👤smeric

Leave a comment