@sergaso

Как сделать left outer join, используя flask-sqlalchemy?

Есть три таблицы:

class User(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    score = db.Column(db.Integer, nullable=False, default=0)
    results = db.relationship('Result', backref='solver', lazy='dynamic')

class Riddle(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    text = db.Column(db.String, unique=True, nullable=False)
    answer = db.Column(db.String, nullable=False)
    solutions = db.relationship('Result', backref='rebus', lazy='dynamic')
    points = db.Column(db.Integer, default=1)

class Result(db.Model):
    id = db.Column(db.Integer, primary_key=True) 
    user_id = db.Column(db.Integer, db.ForeignKey('user.id'))
    riddle_id = db.Column(db.Integer, db.ForeignKey('riddle.id'))


Каким образом можно получить все поля с загадками, которые пользователь не имеет в своих результатах (user.results)?
  • Вопрос задан
  • 210 просмотров
Решения вопроса 1
@sergaso Автор вопроса
Решение было найдено:

SELECT *
FROM riddle
EXCEPT
SELECT riddle.*
FROM riddle
JOIN result ON result.riddle_id = riddle.id
WHERE result.user_id = 1


riddle = Riddle.query.filter(Riddle.theme == theme_id) \
            .except_(Riddle.query.join(Result, Result.riddle_id == Riddle.id) \
            .filter(Result.user_id == user.id)).all()
Ответ написан
Комментировать
Пригласить эксперта
Ответы на вопрос 1
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы