0

我有一个具有以下结构的 MySQL 数据库,希望有人可以帮助我将下面的 SQL 查询转换为 SQLAlchemy。

数据库结构:

**bottom:**
id
name
middle_id

**middle:**
id
name
top_id

**top:**
id
name

这是我的模型:

class Bottom(db.Model):
    id        = db.Column(db.Integer, primary_key=True)
    name      = db.Column(db.String(64))
    middle_id = db.Column(db.Integer, db.ForeignKey('middle.id'))
    middle    = db.relationship('Middle',
        backref=db.backref('bottoms', lazy='dynamic'))

class Middle(db.Model):
    id        = db.Column(db.Integer, primary_key=True)
    name      = db.Column(db.String(64))
    top_id    = db.Column(db.Integer, db.ForeignKey('top.id'))
    top       = db.relationship('Top',
        backref=db.backref('middles', lazy='dynamic'))

class Top(db.Model):
    id        = db.Column(db.Integer, primary_key=True)
    name      = db.Column(db.String(64))

这是我要转换为 SQLAlchemy 的 SQL:

SELECT
  b.*,
  m.*,
  t.*
FROM bottom AS b
  LEFT JOIN (SELECT id, name, top_id  from middle) AS m  on m.id = b.middle_id
  LEFT JOIN (SELECT id, name FROM top) AS t   on t.id = m.top_id
WHERE b.name LIKE '%query%' OR m.name LIKE '%query%' OR t.name LIKE '%query%'

表格底部的每个条目都与中间相关,中间的每个条目都与顶部相关。我想查询数据库以查找底部的所有条目,其名称为 LIKE %query%,底部的所有条目的中间名称为 LIKE %query%,以及底部所有条目的条目,中间的顶部名称是 LIKE查询

我想将其转换为 SQLAlchemy,如下所示:

    return db.session.query(Bottom).filter( or_(Bottom.name.like('%query%'),
                                     Bottom.middle.name.like('%query%'),
                                     Bottom.middle.top.name.like('%query%'))
                                     )).all()

换句话说,如果我在底部有一个与中间条目相关的条目,并且中间的条目与顶部的条目相关,如果我在顶部搜索适当的名称,它将不会返回中间条目与它相关,但与相关的中间条目相关的底部条目。

这是一个例子:

数据:

**bottom**
id        1
name      "Gus Fring"
middle_id 1

**middle**
id        1
name      "Jesse Pinkman"
top_id    1

**top**
id        1
name      "Walter White"

如果我搜索“Walter White”,它不会返回中间关系(Jesse Pinkman),而是返回底部关系到中间关系的结果(Gus Fring)。

先感谢您 :)。

4

1 回答 1

1
name_filter = '%query%'
qry = (session.query(Bottom).
        outerjoin(Middle).
        outerjoin(Top).
        filter(or_(
            Bottom.name.like(name_filter),
            Middle.name.like(name_filter),
            Top.name.like(name_filter),
            ))
        )

作为此查询执行的结果,您将仅获得 Bottom 的实例。如果您真的希望将它们中的所有 3 个作为元组(底部、中间、顶部),只需将query(...)部分替换为session.query(Bottom, Middle, Top).

于 2012-07-02T12:09:38.280 回答