使用sqlalchemy执行删除和提交时出错

时间:2017-11-06 20:08:57

标签: sqlalchemy sqlalchemy-utils

我收到一个错误,当我在删除后执行会话提交时我不明白:(在带有烧瓶应用上下文的shell中或在运行应用时的任何地方)

>>> from app.extensions import db
>>> from app.models.user import User
>>> user = User.query.all()[0]
>>> db.session.delete(user)
>>> db.session.commit()
  

文件   " /Users/hugo/Dropbox/lahey/api/.venv/lib/python3.6/site-packages/sqlalchemy/util/langhelpers.py" ;,   第962行,在模块中       %(self._il_path,self._il_addtl))ImportError:importlater.resolve_all()没有被调用(这是sqlalchemy.orm   strategy_options)

我尝试删除的对象的模型如下所示:

import datetime
from sqlalchemy_utils.types.password import PasswordType
from sqlalchemy_utils import force_auto_coercion

from app.extensions import db

# Setup coercion of passwords
force_auto_coercion()


class User(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    email = db.Column(db.String(120), unique=True, nullable=False)
    password = db.Column(PasswordType(schemes=['pbkdf2_sha512']), nullable=False)
    name = db.Column(db.String(256))
    created_at = db.Column(db.DateTime, default=datetime.datetime.now)
    updated_at = db.Column(db.DateTime, onupdate=datetime.datetime.now)

删除其他模型的对象可以正常工作。这可能是因为我使用了sqlalchemy_utils的PasswordType列吗?

2 个答案:

答案 0 :(得分:0)

如果您使用Flask,则说明您配置Column错误:

Lazy configuration of the type with Flask config:

        import flask
        from sqlalchemy_utils import PasswordType, force_auto_coercion

        force_auto_coercion()

        class User(db.Model):

            __tablename__ = 'user'

            password = db.Column(
                PasswordType(
                    # The returned dictionary is forwarded to the CryptContext
                    onload=lambda **kwargs: dict(
                        schemes=flask.current_app.config['PASSWORD_SCHEMES'],
                        **kwargs
                    ),
                ),
                unique=False,
                nullable=False,
            )

答案 1 :(得分:0)

我找出了导致这种情况的原因。我一直在使用包sqlalchemy_bulk_lazy_loader 有一个错误(strategy_options没有以正确的方式导入)。问题现在是fixed in the package

有关详细信息,请参阅完整sqlalchemy mail list thread