有人能告诉我如何在sqlalchemy中完成这项工作吗?
SELECT
*
FROM animals a
INNER JOIN species s
ON (s.species_id=a.id AND s.type='mammals')
LIMIT 1;
我尝试了很多不同的东西,但是我一直得到奇怪的结果。如果有人请帮助我,我会非常感激。
我做过的一些代码:
result = session.query(Animal).\
join((Species, (Species.species_id==Animal.id)), (Species, (Species.type=='mammals')))
.all()
这当然给了我:
SELECT
*
FROM animals
INNER JOIN species
ON (species.species_id=animals.id)
INNER JOIN species
ON (AND species.type='mammals')
LIMIT 1;
但这不是我想要的。
提前致谢。
-e
答案 0 :(得分:0)
您只需要and_
:
from sqlalchemy.sql import and_
result = session.query(Animal).join(Species, and_(
Species.species_id == Animal.id,
Species.type == 'mammals',
)).all()
编辑:这是使用SQLAlchemy 0.7及更高版本中提供的join
的“双参数调用表单”。