[英]How to reset db in Django? I get a command 'reset' not found error
在此 Django 之后通过示例教程在这里: http://lightbird.net/dbe/todo_list.html
教程说:
“这会改变我们的表格布局,我们必须要求 Django 重置和重新创建表格:
manage.py reset todo; manage.py syncdb
manage.py reset todo; manage.py syncdb
“
但是,当我运行manage.py reset todo
时,出现错误:
$ python manage.py reset todo
- Unknown command: 'reset'
这是因为我使用的是 sqlite3 而不是 postgresql?
有人能告诉我重置数据库的命令是什么吗?
命令: python manage.py sqlclear todo
返回错误:
$ python manage.py sqlclear todo
CommandError: App with label todo could not be found.
Are you sure your INSTALLED_APPS setting is correct?
所以我在 settings.py 中将“todo”添加到我的 INSTALLED_APPS 中,然后再次运行python manage.py sqlclear todo
,导致此错误:
$ python manage.py sqlclear todo
- NameError: name 'admin' is not defined
reset
已被 Django 1.5 替换为flush
,请参阅:
python manage.py help flush
看起来“刷新”答案适用于某些情况,但并非所有情况。 我不仅需要刷新数据库中的值,还需要正确地重新创建表。 我还没有使用迁移(早期)所以我真的需要删除所有表。
我发现删除所有表的两种方法,都需要核心 django 以外的东西。
如果您使用 Heroku,请使用 pg:reset 删除所有表:
heroku pg:reset DATABASE_URL
heroku run python manage.py syncdb
如果你可以安装 Django 扩展,它有一种方法可以完全重置:
python ./manage.py reset_db --router=default
与 LisaD 的回答类似, Django Extensions有一个很棒的 reset_db 命令,可以完全删除所有内容,而不仅仅是像“flush”那样截断表。
python ./manage.py reset_db
仅仅刷新表并不能修复我删除对象时发生的持久性错误。 做一个 reset_db 解决了这个问题。
如果您使用的是 Django 2.0 那么
python manage.py flush
将工作
如果要清理整个数据库,可以使用: python manage.py flush如果要清理 Django 应用程序的数据库表,可以使用: python manage.py migrate appname zero
使用 django 1.11,只需从每个应用程序的migrations
文件夹中删除所有迁移文件(除__init__.py
之外的所有文件)。 然后
python3 manage.py makemigrations
。python3 manage.py migrate
。瞧,您的数据库已完全重置。
对我来说,这解决了问题。
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
只是对@LisaD 的回答的跟进。
截至 2016 年( Django 1.9
),您需要输入:
heroku pg:reset DATABASE_URL
heroku run python manage.py makemigrations
heroku run python manage.py migrate
这将为您在 Heroku 中提供一个全新的数据库。
python manage.py flush
删除旧的数据库内容,
不要忘记创建新的超级用户:
python manage.py createsuperuser
只需手动删除您的数据库。 确保首先创建备份(在我的情况下db.sqlite3是我的数据库)
运行此命令manage.py migrate
我在 django 4.1 上使用python manage.py flush
和 postreSQL
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.