Python中使用sqlalchemy查询时提示“TypeError: expected string or Unicode object, int found”如何解决

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)

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


Python中使用sqlalchemy查询时提示“TypeError: expected string or Unicode object, int found”如何解决

6 回复

id=‘1’ 试一下


这个问题通常是因为在SQLAlchemy的查询条件中,字符串字段被传入了整数类型的值。比如你的模型里某个字段是String类型,但查询时用了整数去匹配。

看个例子,假设有这样一个模型:

from sqlalchemy import Column, Integer, String, create_engine
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker

Base = declarative_base()

class User(Base):
    __tablename__ = 'users'
    id = Column(Integer, primary_key=True)
    name = Column(String(50))
    age = Column(Integer)

engine = create_engine('sqlite:///:memory:')
Base.metadata.create_all(engine)
Session = sessionmaker(bind=engine)
session = Session()

错误写法:

# 假设name是String字段,但传入了整数
result = session.query(User).filter(User.name == 123).all()  # 这里会报错

正确写法:

# 字符串字段必须传入字符串
result = session.query(User).filter(User.name == "123").all()  # 正确

# 或者对于整数字段可以传入整数
result = session.query(User).filter(User.age == 25).all()  # 正确

检查你的查询条件,确保每个字段的类型和传入值的类型匹配。如果是从外部接收参数,可以用str()转换一下。

总结:检查查询条件中的类型匹配。

对 改成 string 后就是这么查询的,还是一样的报错

看一下之前的表,去看看表中字段类型

你好,我发现 db.query(Blog.name).filter_by(id=1).first()和 db.query(Blog.id).filter_by(id=1).first()这样是没问题的

问题解决了,自己也备注下吧,原来是对 sqlalchemy 数据类型使用不够深入导致的
有个字段是 type = Column(ChoiceType(TYPES),default=6666),然后 TYPES=[
(0, u"情感"),
(1, u"生活"),
(2, u"编码"),
(6666, u"其它")
]

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

回到顶部