簡體   English   中英

使用sqlalchemy時如何進行高級聯接?

[英]How to do advance joins when using sqlalchemy?

有人可以告訴我如何在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

您只需要and_

from sqlalchemy.sql import and_

result = session.query(Animal).join(Species, and_(
    Species.species_id == Animal.id,
    Species.type == 'mammals',
)).all()

編輯:這是利用“兩個參數調用形式”的join在SQLAlchemy的0.7及更高版本。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM