pyqb

导航

 

转自:(http://blog.csdn.net/Super_Tiger_Lee/article/details/77772752

1、模型初始化环境:

命令:python manage.py db init 
cmd的回应:

Creating directory F:\code\flask_project\migrations ... done Creating directory 
F:\code\flask_project\migrations\versions ... done Generating 
F:\code\flask_project\migrations\alembic.ini ... done Generating 
F:\code\flask_project\migrations\env.py ... done Generating 
F:\code\flask_project\migrations\env.pyc ... done Generating 
F:\code\flask_project\migrations\README ... done Generating 
F:\code\flask_project\migrations\script.py.mako ... done Please edit 
configuration/connection/logging settings in 
'F:\\code\\flask_project\\migrations\\alembic.ini' before proceeding.

2、把表中模型映射到数据库中 先生成迁移文件

命令:python manage.py db migrate 
cmd回应:

INFO  [alembic.runtime.migration] Context impl MySQLImpl.
INFO  [alembic.runtime.migration] Will assume non-transactional DDL.
INFO  [alembic.autogenerate.compare] Detected added table 'answer'
Generating F:\code\flask_project\migrations\versions\3007cf54a530_.py ... done

这时打开migration文件夹后再打开versions文件夹会看到形如3007cf54a530_.py文件和3007cf54a530_.cpy文件


3、再把迁移文件映射到数据库中 
命令:python manage.py db upgrade 
cmd回应:

INFO  [alembic.runtime.migration] Context impl MySQLImpl.
INFO  [alembic.runtime.migration] Will assume non-transactional DDL.
INFO  [alembic.runtime.migration] Running upgrade  -> 3007cf54a530, empty message

以上是正常的情况 
今天我手残,项目做到一半把migrations文件误删了,而且这个文件删除后是无法找回的,回收站里是找不到的 
于是我重新执行步骤一,成功 
执行步骤二,报错:

alembic.util.exc.CommandError: Can't locate revision identified by '68c8e45e399c'

 

后来终于找到一篇相关文章 
把问题解决了

我的理解是: 
当把后台与数据库建立关系后,双方会分别产生一个“接口”,后台的“接口”是migrations文件夹中的versions文件夹中的文件;数据库的“接口”是这个表“alembic_version”(蒸馏器版本?什么鬼名字?) 
我把migrations删除后,alembic_version没有改变。当我新建一个migrations后,两个“接口”对不上了,所以会报错: 
alembic.util.exc.CommandError: Can't locate revision identified by '68c8e45e399c' 

所以这种错误最简单的解决办法就是把数据库中的alembic_version表删掉,然后就可以继续后面的操作了

 

posted on 2017-10-10 12:15  没有音乐就退化耳朵  阅读(880)  评论(0编辑  收藏  举报