各位大神,请教一个 Flask-sqlalchemy 一对多查询的问题。

2017-05-09 01:08:19 +08:00
 ossicee

#请教一个 Flask-sqlalchemy 一对多查询的问题 我最近在自学 Flask,定的目标就是做一个 Blog,但是在导航菜单和导航菜单分类查询的时候遇到了问题,所以来请教一下各位

我的数据库表模型是:

菜单表

class Menus(db.Model):
    __tablename__ = 'menus'

    id = db.Column(db.Integer, primary_key=True)
    menucategory = db.relationship('Category',backref='menus',lazy='dynamic')
    menuName = db.Column(db.String(24), unique=True, index=True, nullable=False)
    orderNo = db.Column(db.Integer)
    visible = db.Column(db.Boolean, default=False)

菜单分类表

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

    id = db.Column(db.Integer,primary_key=True)
    menuid = db.Column(db.Integer,db.ForeignKey('menus.id'))
    categoryName = db.Column(db.String(32),unique=True,index=True)
    orderNo = db.Column(db.Integer)
    visibled = db.Column(db.Boolean,default=False)

我想查询 菜单分类表 但是要把他的外键 menus.id 查询出来, 直接 Sql 语句能实现

SELECT c.id,c.categoryName,c.orderNo,c.visibled,m.menuName FROM Menus m,Category c WHERE c.menuid=m.id

但是用#Flask-sqlalchemy 我查不到数据

categories = Category.query.join(Menus,Category.menuid == Menus.id).add_columns(Category.id,Menus.menuName,Category.orderNo,Category.visibled).filter(Category.menuid == Menus.id)

请教一下,如果用 flask-sqlalchemy 怎么查询。。

3059 次点击
所在节点    Python
8 条回复
coolair
2017-05-09 01:51:06 +08:00
menus = Menus.query.all()
menu.menucategory.id

menu.menuName
ossicee
2017-05-09 08:08:46 +08:00
@coolair 啊。是我想多啦,谢谢回复,我马上去试试
ossicee
2017-05-09 08:10:54 +08:00
@coolair 不对,好像您这个查的是 Menus 表吧
welkinzh
2017-05-09 08:20:47 +08:00
category = Category.query.all()
category.menu.id
这样可以么
welkinzh
2017-05-09 08:22:27 +08:00
那个 all() 写错了 应该是 filter()...
node
2017-05-09 09:15:37 +08:00
Category.query.options(db.Load(Category).joinedload('menus')).all()
coolair
2017-05-09 09:30:39 +08:00
@ossicee 有外键,查哪张表有什么关系,数据出来了就行啊。
ossicee
2017-05-09 09:50:07 +08:00
@coolair
@welkinzh 感谢两位,,确实是这样的,是我想多了.谢谢您们的回复和对我的帮助

@node 谢谢您,您的这个方法也可以,现在我就理解一下这个方法,谢谢您的回复和帮助.

第一次在 V2 发帖,而且是提问题.大家都好热心呢,谢谢 V2

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

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

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

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

© 2021 V2EX