簡體   English   中英

如果記錄具有與之相關的外鍵對象,則過濾SQLAlchemy對象中的記錄

[英]Filter records in SQLAlchemy object if the record has foreign key objects related to it

使用Flask-SQLAlchemy快速入門中的示例:

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) 

由於您想要的只是具有帖子的類別,因此您可以嘗試執行以下操作:

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

該聯接將阻止沒有帖子的任何類別返回。

請注意,distinct函數的用法是,一旦有多個帖子指向同一類別,它將阻止類別重復。 但是,它不能用於Category類本身,因此我在Category.id屬性中使用了它,並添加了Category作為第二個參數來獲取整個對象。 它將返回一個(id,Category)元組的列表。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM