微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

python-为什么SQLAlchemy会将hstore字段初始化为null?

我正在使用Flask-sqlAlchemy,并具有下面的列的模型:

class Item(Model):
    misc = Column(MutableDict.as_mutable(postgresql.HSTORE), nullable=False,
                  server_default='',
                  default=MutableDict.as_mutable(postgresql.HSTORE))

当我尝试将字段分配给模型对象时,杂项列似乎为None,而不是空的dict:

my_item = Item()
my_item.misc["foo"] = "bar"
# TypeError: 'nonetype' object does not support item assignment

如何配置模型,以便使用空字典初始化新对象?

解决方法:

这里有两个问题.首先,认值应该是Python字典,而不是列类型的重复.其次,初始化新实例时不使用认值,只有在提交没有为该列设置值的实例时才使用认值.因此,您还需要在初始化期间专门添加认值.

from sqlalchemy.dialects.postgresql import HSTORE
from sqlalchemy.ext.mutable import MutableDict

class Item(db.Model):
    misc = db.Column(MutableDict.as_mutable(HSTORE), nullable=False, default={}, server_default='')

    def __init__(self, **kwargs):
        kwargs.setdefault('misc', {})
        super(Item, self).__init__(**kwargs)
item = Item()
item.misc['foo'] = 'bar'

值得注意的是,如果只打算从Python使用它,则没有必要同时设置default和server_default.不过也没有害处.

我假设您知道在这种特定情况下需要HSTORE,但是我还要指出Postgresql现在具有更通用的JSON和JSONB类型.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐