sqlalchemy 查询提示“TypeError: expected string or Unicode object, int found”

2018-06-14 15:47:38 +08:00
 Braid

RT

我的 model 之前是这样的:

class Blog(Base):
    __tablename__ = 'blog'
    id = Column(Integer,primary_key=True)
    title = Column(String(200))
    add_time = Column(DateTime, default=datetime.now)
    update_time = Column(DateTime, default=datetime.now)

    def __repr__(self):
        return "%d" % (self.id)

然后我创建了 sqlalchemy 的 db session,去查询这个表的语句如下:

db.query(Blog).filter_by(id=1).first()

发现报错“ TypeError: expected string or Unicode object, int found ”

然后我开始是怀疑 def repr(self):的问题,网上有提示说不支持 int 类型,那么我将 model 里的 id 改成了字符串类型,如下:

class Blog(Base):
    __tablename__ = 'blog'
    id = Column(String(50),primary_key=True)
    title = Column(String(200))
    add_time = Column(DateTime, default=datetime.now)
    update_time = Column(DateTime, default=datetime.now)

    def __repr__(self):
        return "%s" % (self.id)

但还是报错,真的很囧,求大佬帮助,十分感谢!

1616 次点击
所在节点    Python
5 条回复
linuxchild
2018-06-14 15:54:54 +08:00
id='1' 试一下
Braid
2018-06-14 15:55:43 +08:00
@linuxchild 对 改成 string 后就是这么查询的,还是一样的报错
linuxchild
2018-06-14 15:58:10 +08:00
@Braid 看一下之前的表,去看看表中字段类型
Braid
2018-06-14 16:02:05 +08:00
@linuxchild 你好,我发现 db.query(Blog.name).filter_by(id=1).first()和 db.query(Blog.id).filter_by(id=1).first()这样是没问题的
Braid
2018-06-14 16:42:58 +08:00
问题解决了,自己也备注下吧,原来是对 sqlalchemy 数据类型使用不够深入导致的
有个字段是 type = Column(ChoiceType(TYPES),default=6666),然后 TYPES=[
(0, u"情感"),
(1, u"生活"),
(2, u"编码"),
(6666, u"其它")
]

如果是这种 int 类型的一一对应,那么正确的使用方式是 type = Column(ChoiceType(TYPES,Integer()),default=6666)

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/463116

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX