请教各位一个关于 Flask-sqlalchemy group_by 的问题

2017-05-31 21:53:08 +08:00
 ossicee

各位大神,菜鸟一枚 我有一个文章表 模型是

class Post(db.Model):
    __tablename__ = 'post'

    id = db.Column(db.Integer, primary_key=True)
    title = db.Column(db.String(32), unique=True)
    body = db.Column(db.Text)
    author_id = db.Column(db.Integer, db.ForeignKey('user.id'))
    category_id = db.Column(db.Integer, db.ForeignKey('category.id'))

有一个分类表 模型是

class Category(db.Model):
    __tablename__ = 'category'

    id = db.Column(db.Integer, primary_key=True)
    posts = db.relationship('Post', backref='postcategory', lazy='dynamic')
    categoryName = db.Column(db.String(32), unique=True, index=True)

我想查出category 文章分类每个分类有多少篇文章

我有 sql 能查,语句是

SELECT COUNT(id),(SELECT categoryName from category WHERE post.category_id=category.id) as N FROM post GROUP BY category_id

请教一下各位大神,如果用 flask-sqlalchemy 怎么写呀 谢谢各位了

5062 次点击
所在节点    Python
5 条回复
ossicee
2017-06-01 09:26:27 +08:00
💪
fangzq
2017-06-01 11:09:28 +08:00
可以试试这个:

```python
from sqlalchemy import func
db.session.query(func.count(Post.id), Category.categoryName).select_from(Category).\
join(Post, Category.id == Post.category_id).group_by(Post.category_id).all()
```
ossicee
2017-06-01 15:56:08 +08:00
@fangzq 谢谢您,我等下回家测试一下,谢谢您帮助我
ossicee
2017-06-03 10:50:02 +08:00
@fangzq 谢谢您,,。。原来我查资料,关键字全是 flask-sqlalchemy .原来用 sqlalchemy 就可以完成。谢谢您
fangzq
2017-06-05 09:26:51 +08:00
解决了就好,不客气

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/365041

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX