You need to enable JavaScript to run this app.
最新活动
大模型
产品
解决方案
定价
生态与合作
支持与服务
开发者
了解我们

继承带有table=True且包含非基础字段类型的SQLModel父类时触发ValueError的问题咨询

继承带有table=True且包含非基础字段类型的SQLModel父类时触发ValueError的问题咨询

大家好,我在使用sqlmodel 0.0.22版本时碰到了一个棘手的问题,想请教下各位:

当我定义一个标记了table=True的SQLModel父类,其中包含一个通过sa_type=ARRAY(String)指定类型的list[str]字段,再继承这个父类创建子类时,程序会直接崩溃,抛出错误:

ValueError: <class 'list'> has no matching SQLAlchemy type

我的代码如下:

from sqlalchemy import ARRAY
from sqlmodel import Field, SQLModel, String


class Foo(SQLModel, table=True):
    id: str = Field(primary_key=True)
    bar: list[str] = Field(sa_type=ARRAY(String))


class Bar(Foo):
    pass

我尝试过把父类的table=True去掉,这时候错误就消失了,但这样的话父类就无法对应到数据库表,不符合我的实际需求。

有没有朋友知道这个问题的原因是什么?有没有可行的解决办法或者替代方案呢?

备注:内容来源于stack exchange,提问作者tierriminator

火山引擎 最新活动