V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
ossicee
V2EX  ›  Python

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

  •  
  •   ossicee · 2017-05-09 01:08:19 +08:00 · 3061 次点击
    这是一个创建于 2748 天前的主题,其中的信息可能已经有所发展或是发生改变。

    #请教一个 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 怎么查询。。

    8 条回复    2017-05-09 09:50:07 +08:00
    coolair
        1
    coolair  
       2017-05-09 01:51:06 +08:00 via Android
    menus = Menus.query.all()
    menu.menucategory.id

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

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

    第一次在 V2 发帖,而且是提问题.大家都好热心呢,谢谢 V2
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2570 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 21ms · UTC 01:36 · PVG 09:36 · LAX 17:36 · JFK 20:36
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.