【发布时间】:2016-06-16 23:10:52
【问题描述】:
当我将 SQLAlchemy 与 Oracle 一起使用时,我还必须为主键添加序列,但迁移不会自行创建序列。如何获得要创建的序列?
我已经尝试多次调整代码以让 SQLAlchemy 为主键创建 oracle 序列,但到目前为止,我还无法获得由 SQLAlchemy 创建的 Oracle 序列。到目前为止,我有一个非常简单的用户/角色设置,并且存在表,但不存在序列。它运行时没有显示错误。
Model 类如下所示:
class Role(SurrogatePK, Model):
"""A role for a user."""
__tablename__ = 'roles'
id = db.Column(db.Integer, db.Sequence(__tablename__ + '_id_seq'), primary_key=True)
name = Column(db.String(80), unique=True, nullable=False)
user_id = reference_col('users', nullable=True)
user = relationship('User', backref='roles')
def __init__(self, name, **kwargs):
"""Create instance."""
db.Model.__init__(self, name=name, **kwargs)
我正在使用 Flask 和 SQLAlchemy,并且在我运行之后;
$ python manage.py db init
Creating directory <lots removed here>...done
$ $ python manage.py db migrate
INFO [alembic.runtime.migration] Context impl OracleImpl.
INFO [alembic.runtime.migration] Will assume non-transactional DDL.
INFO [alembic.autogenerate.compare] Detected added table 'users'
INFO [alembic.autogenerate.compare] Detected added table 'roles'
我没有发现任何错误,一切看起来都很好。然而,在我跑完之后;
$ python manage.py db upgrade
INFO [alembic.runtime.migration] Context impl OracleImpl.
INFO [alembic.runtime.migration] Will assume non-transactional DDL.
INFO [alembic.runtime.migration] Running upgrade -> 61ca5eb70d06, empty message
我第一次尝试创建记录,它失败并显示:
sqlalchemy.exc.DatabaseError DatabaseError: (cx_Oracle.DatabaseError) ORA-02289: 序列不存在
如果我手动创建序列,它工作正常。
【问题讨论】:
-
您是否在使用自动生成的 alembic 迁移脚本?
-
alembic 不是一个完全自动化的解决方案。您必须手动调整创建的迁移文件,因为它无法自行解决。在这种情况下,您似乎必须手动添加代码来创建/删除序列。
-
啊,谢谢你提供的信息。
标签: python oracle flask sqlalchemy flask-sqlalchemy