【问题标题】:Filter records in SQLAlchemy object if the record has foreign key objects related to it如果记录具有与其相关的外键对象,则过滤 SQLAlchemy 对象中的记录
【发布时间】:2015-09-22 03:49:15
【问题描述】:

使用来自the Flask-SQLAlchemy Quickstart的示例:

from datetime import datetime

class Post(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    title = db.Column(db.String(80))
    body = db.Column(db.Text)
    pub_date = db.Column(db.DateTime)

    category_id = db.Column(db.Integer, db.ForeignKey('category.id'))
    category = db.relationship('Category',
        backref=db.backref('posts', lazy='dynamic'))

    def __init__(self, title, body, category, pub_date=None):
        self.title = title
        self.body = body
        if pub_date is None:
            pub_date = datetime.utcnow()
        self.pub_date = pub_date
        self.category = category

    def __repr__(self):
        return '<Post %r>' % self.title


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

    def __init__(self, name):
        self.name = name

    def __repr__(self):
        return '<Category %r>' % self.name

我以与示例相同的方式重新创建了类别和帖子:

>>> py = Category('Python')
>>> p = Post('Hello Python!', 'Python is pretty cool', py)
>>> db.session.add(py)
>>> db.session.add(p)
>>> py.posts.all()
[<Post 'Hello Python!'>]

然后我添加一个新类别:

>>> ru = Category('Ruby')
>>> db.session.add(ru)

如何构造查询以获取所有包含帖子的类别。

想做这样的事情,但使用 SQLAlchemy 过滤器代替:

>>> categories_with_post = []
>>> For c in Category.query.all():
...     if len(c.posts.all()) > 0:
...         categories_with_post.append(c) 

【问题讨论】:

    标签: python flask sqlalchemy flask-sqlalchemy


    【解决方案1】:

    由于您想要的只是具有帖子的类别,因此您可以尝试以下操作:

    from sqlalchemy import distinct
    db.session.query(distinct(Category.id), Category).join(Post.category).all()
    

    加入将阻止任何没有帖子的类别被退回。

    注意distinct函数的使用,当多个帖子指向同一类别时,它将防止类别重复。但是它不能用于 Category 类本身,所以我在Category.id 属性中使用它,并添加Category 作为第二个参数来获取整个对象。它将返回 (id, Category) 元组的列表。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2017-07-07
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2019-11-26
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多