我有一个具有以下结构的 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)。
先感谢您 :)。