gpt4 book ai didi

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

转载 作者:太空宇宙 更新时间:2023-11-03 15:09:46 24 4
gpt4 key购买 nike

我正在使用 Flask-SQLAlchemy 并且有一个包含以下列的模型:

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

当我尝试将字段分配给模型对象时,misc 列似乎是 None,而不是空字典:

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

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

最佳答案

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

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 中使用它,那么设置 defaultserver_default 是没有意义的。不过也没有坏处。


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

关于python - 为什么 SQLAlchemy 将 hstore 字段初始化为空?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28331046/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com