使用SQLalchemy我想执行左外连接,过滤掉在连接表中具有匹配项的行。
我正在发送推送通知,因此我有一个Notification
表。这意味着我还有一个ExpiredDeviceId
表来存储不再有效的device_ids。 (我不想删除受影响的通知,因为用户以后可能会重新安装应用程序,此时通知应根据Apple的文档恢复。)
CREATE TABLE Notification (device_id TEXT, time DATETIME);
CREATE TABLE ExpiredDeviceId (device_id TEXT PRIMARY KEY, expiration_time DATETIME);
注意:每个device_id可能有多个通知。每个设备都没有“设备”表。
所以在做SELECT FROM Notification
时我应该相应地过滤。我可以在SQL中做到这一点:
SELECT * FROM Notification
LEFT OUTER JOIN ExpiredDeviceId
ON Notification.device_id = ExpiredDeviceId.device_id
WHERE expiration_time IS NULL
但是我怎么能在SQLalchemy中做到这一点?
sess.query(
Notification,
ExpiredDeviceId
).outerjoin(
(ExpiredDeviceId, Notification.device_id == ExpiredDeviceId.device_id)
).filter(
???
)
或者我可以使用device_id NOT IN (SELECT device_id FROM ExpiredDeviceId)
子句执行此操作,但这似乎效率较低。
答案 0 :(得分:14)
你需要在元组中拉回ExpiredDeviceId吗?如果你不这样做(即你只关心live device_ids),那么你不能这样做:
sess.query(
Notification
).outerjoin(
(ExpiredDeviceId, Notification.device_id == ExpiredDeviceId.device_id)
).filter(
ExpiredDeviceId.expiration_time == None
)