我从我的ubuntu安装了alembic 0.3.4,sqlalchemy,SQLite版本3.7.4,并将SQLAlchemy 0.6.4升级到SQLAlchemy 0.7或更高版本。 我按照说明操作:http://alembic.readthedocs.org/en/latest/tutorial.html
现在我正在测试:自动生成迁移 我创建了一个包:schemas,以及模式下的包标记: init .py 定义了一行:
__all__ = ["teacher"]
我还在schemas目录中创建了一个模块文件:dbmodel.py,其内容低于内容
Base = declarative_base()
class teacher(Base):
__tablename__ = 'teacher'
id = Column(Integer, primary_key=True)
name = Column(String)
department = Column(String)
顺便说一下,我创建了一个sqlite数据库,并且在自动生成迁移之前进行一些测试它运行正常。我配置了env.py文件。添加了两行:
from schemas.dbmodel import Base
target_metadata = Base.metadata
然后我跑:
alembic revision --autogenerate -m "Added teacher table"
但仍然出错:
Traceback (most recent call last):
File "/usr/local/bin/alembic", line 9, in <module>
load_entry_point('alembic==0.3.4', 'console_scripts', 'alembic')()
File "/usr/local/lib/python2.7/dist-packages/alembic-0.3.4-py2.7.egg/alembic/config.py", line 229, in main
**dict((k, getattr(options, k)) for k in kwarg)
File "/usr/local/lib/python2.7/dist-packages/alembic-0.3.4-py2.7.egg/alembic/command.py", line 93, in revision
script.run_env()
File "/usr/local/lib/python2.7/dist-packages/alembic-0.3.4-py2.7.egg/alembic/script.py", line 188, in run_env
util.load_python_file(self.dir, 'env.py')
File "/usr/local/lib/python2.7/dist-packages/alembic-0.3.4-py2.7.egg/alembic/util.py", line 185, in load_python_file
module = imp.load_source(module_id, path, open(path, 'rb'))
File "alembic/env.py", line 20, in <module>
from schemas.dbmodel import Base
ImportError: No module named schemas.dbmodel
我不知道为什么使用alembic测试一个简单的例子是如此困难。我只想将我的应用程序数据模型导入到物理数据库模型中。这太复杂了吗?谢谢。请知道alembic的人给我们一步一步的简单介绍。我想更多的人会从中受益。
答案 0 :(得分:23)
我还发现Alembic无法找到我的模型模块。作为一种解决方法,我发现通过在导入模型之前将以下内容添加到env.py
,我可以强制它起作用:
import os, sys
sys.path.append(os.getcwd())
这可能不是最好的解决方案,但让Alembic自动生成我的迁移。