【问题标题】:How to write select statement in sqlachemy [duplicate]如何在sqlalchemy中编写select语句[重复]
【发布时间】:2013-12-19 15:49:21
【问题描述】:

我想在sqlachemy中做select语句

select user.id from user where user.name = 'test'

我通过以下方式加载用户表:

User = Table('user',metadata,autoload=True)
Result = session.query(User.c.id).filter_by(name='test').first()

我遇到了一个错误

“NoInspectionAvailable: 没有可用于“类型”对象的检查系统

您能建议如何在 sqlachemy 中执行该 SQL 吗?

【问题讨论】:

  • 为什么是User.c.id 而不是User.id
  • @fedorqui 如果是 User.id,我会得到“'Table' 对象没有属性 'id'”
  • @alKid 我不想创建一个用于映射的类,只想使用 Table 对象。而且,如果您在给我的链接中更加仔细,则没有将查询和过滤子句一起使用的参考。

标签: python sqlalchemy


【解决方案1】:

已解决:

r =session.query(statSoftware.c.id).filter(statSoftware.c.name=='Apache').first()

使用filter() 代替filter_by(),允许获取所有需要的列。

【讨论】:

  • 查看here 了解差异。
  • 我见过,但 filter_by(name='test') 在这种情况下不起作用。你能建议如何在我的情况下使用 filter_by 吗?
  • 因为您指定了statSoftware.c.id,所以没有简单的方法可以做到这一点。当您指定filter_by 时,它会查看queryjoin 函数指定的最后一个实体。但是,您在query 中指定了一个列,而不是一个表。 SQLAlchemy 0.9(尚未正式发布)有load_only,这可以使这更容易。但实际上,我仍然建议使用 filter
猜你喜欢
  • 2011-08-08
  • 1970-01-01
  • 2013-07-07
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-12-05
  • 1970-01-01
  • 2020-01-08
相关资源
最近更新 更多