尝试将变量(一组)传递到sqlalchemy查询中。将变量传递给SQLAlchemy查询
找到这个:How can I bind a list to a parameter in a custom query in sqlalchemy?但它需要你知道有很多项目。在任何特定时刻条目的数量都会发生变化。
我的previous question大部分没有回答,所以我想我会重新尝试我在这里要做的事情。
基本上,我有这个变量:sites = set(db1).intersection(db2)
,我试图将其传递到这个SQL查询炼金术:
'test': DBSession.query(A_School.cis_site_id.in_(sites)).all(),
,但我得到invalid syntax
错误和invalid parameter type
错误......我不能让这件事情做我想做的事情。正如你可能猜到的那样,DB1和DB2是2个不同的数据库。
db1 = cis_db.query(site.site_id).join(site_tag).filter(site_tag.tag_id.like(202)).all()
db2 = DBSession.query(A_School.cis_site_id).all()
完整的错误:
ProgrammingError: (ProgrammingError) ('Invalid parameter type. param-index=0 param-type=KeyedTuple', 'HY105') u'SELECT [A_School].cis_site_id IN (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?) AS anon_1
FROM [A_School]' ((14639,), (14709,), (14587,), (14966,), (14625,), (14589,), (15144,), (15171,) ... displaying 10 of 18 total bound parameter sets ... (15133,), (14036,))