python flask 多对多表查询功能

发布时间 - 2026-01-11 02:02:29    点击率:

我们在flask的学习中,会难免遇到多对多表的查询,今天我也遇到了这个问题。那么我想了好久。也没有想到一个解决的办法,试了几种方法,可能是思路的限制我放弃了,后来,我就在网上百度,可是发现百度出来的结果和自己想要的还有一定的差距,那么我根据百度上得来的思路,那么我也对我的数据结构进行了探索, 下面来看看我这里怎么来查询的,首先给大家看下我写的数据库的代码的片段,这样,加深理解。

post_class=db.Table('post_class',
  db.Column('post_id',db.Integer(),db.ForeignKey('posts.id')),
  db.Column('classifa_id',db.Integer(),db.ForeignKey('fenlei.id')))
class Post(db.Model):#文章表
  __tablename__='posts'
  id=db.Column(db.Integer,primary_key=True,autoincrement=True)
  title=db.Column(db.String(255),unique=True)
  text=db.Column(db.Text())
  publish_date=db.Column(db.DateTime,default=datetime.datetime.now())
  user_id=db.Column(db.Integer,db.ForeignKey('users.id'))
  is_recomment=db.Column(db.Boolean,default=False)
  comments = db.relationship(
    'Comment',
    backref='posts',
    lazy='dynamic')
  tag = db.relationship(
    'Tag',
    secondary=posts_tags,
    backref=db.backref('posts', lazy='dynamic')
  )
  classname=db.relationship('Classifa',
    secondary=post_class,
    backref=db.backref('posts'))
  def __repr__(self):
    return "<Model Post `{}`>".format(self.title)
class Classifa(db.Model):#分类
  __tablename__='fenlei'
  id=db.Column(db.Integer(),primary_key=True)
  name=db.Column(db.String(64))
  def __repr__(self):
    return self.name

这里有三张表,一张呢是文章的列表,另一张呢,是分类表,我们来想下,一篇文章可能同时属于多个分类,那么一个分类可能也属于多个文章,这么来说想必我们大家都能理解这个逻辑,那么呢,我第三表来显示多对多关系的,那么我们接下来怎么去查询呢,其实我现在的需求就是我要找个一个分类下面所有的文章吧,

下面来看看我的代码

data=Classifa.query.filter_by(name='数据库').first()
 data_post=data.posts

这里呢,我直接先从分类找到这个分类,然后通过第三表来查询属于这个分类的文章、其实呢 这里很简单,可能是我当时自己的脑子短路了吧, 不知道怎么想是对的,现在来看 其实还是那么的简单,只是当时我忽略了什么。    加油,学习前进的路上。


# python  # flask  # 多对多查询  # 使用Python & Flask 实现RESTful Web API的实例  # Python利用flask sqlalchemy实现分页效果  # python flask实现分页效果  # win系统下为Python3.5安装flask-mongoengine 库  # 使用Python的Flask框架表单插件Flask-WTF实现Web登录验证  # Python的Flask框架标配模板引擎Jinja2的使用教程  # 深度定制Python的Flask框架开发环境的一些技巧总结  # Flask解决跨域的问题示例代码  # 我也  # 多个  # 自己的  # 我就  # 对我  # 我现在  # 都能  # 这个问题  # 有一定  # 数据结构  # 给大家  # 看我  # 很简单  # 想了  # 就是我  # 来看看  # 没有想到  # 不知道怎么  # 我写  # 得来 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何实现模型的全局作用域?(Global Scope示例)  高配服务器限时抢购:企业级配置与回收服务一站式优惠方案  Java解压缩zip - 解压缩多个文件或文件夹实例  JavaScript如何实现错误处理_try...catch如何捕获异常?  Android中AutoCompleteTextView自动提示  Laravel Pest测试框架怎么用_从PHPUnit转向Pest的Laravel测试教程  如何在万网主机上快速搭建网站?  如何挑选优质建站一级代理提升网站排名?  JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)  Laravel Admin后台管理框架推荐_Laravel快速开发后台工具  Laravel中DTO是什么概念_在Laravel项目中使用数据传输对象(DTO)  如何打造高效商业网站?建站目的决定转化率  JavaScript Ajax实现异步通信  Laravel怎么实现前端Toast弹窗提示_Laravel Session闪存数据Flash传递给前端【方法】  使用豆包 AI 辅助进行简单网页 HTML 结构设计  如何在服务器上三步完成建站并提升流量?  Laravel怎么集成Log日志记录_Laravel单文件与每日日志配置及自定义通道【详解】  Win11怎么恢复误删照片_Win11数据恢复工具使用【推荐】  Win11应用商店下载慢怎么办 Win11更改DNS提速下载【修复】  如何快速查询网址的建站时间与历史轨迹?  作用域操作符会触发自动加载吗_php类自动加载机制与::调用【教程】  Laravel如何生成和使用数据填充?(Seeder和Factory示例)  Windows10如何删除恢复分区_Win10 Diskpart命令强制删除分区  php增删改查怎么学_零基础入门php数据库操作必知基础【教程】  C语言设计一个闪闪的圣诞树  香港服务器如何优化才能显著提升网站加载速度?  如何在 Pandas 中基于一列条件计算另一列的分组均值  Laravel如何使用Socialite实现第三方登录?(微信/GitHub示例)  如何用VPS主机快速搭建个人网站?  制作旅游网站html,怎样注册旅游网站?  如何挑选最适合建站的高性能VPS主机?  Laravel怎么实现观察者模式Observer_Laravel模型事件监听与解耦开发【指南】  Win11怎么查看显卡温度 Win11任务管理器查看GPU温度【技巧】  如何在宝塔面板中修改默认建站目录?  Laravel如何将应用部署到生产服务器_Laravel生产环境部署流程  用yum安装MySQLdb模块的步骤方法  如何在IIS中新建站点并配置端口与物理路径?  Linux系统命令中screen命令详解  Laravel如何使用Vite进行前端资源打包?(配置示例)  简单实现jsp分页  Laravel如何实现数据导出到PDF_Laravel使用snappy生成网页快照PDF【方案】  文字头像制作网站推荐软件,醒图能自动配文字吗?  敲碗10年!Mac系列传将迎来「触控与联网」双革新  移动端脚本框架Hammer.js  大型企业网站制作流程,做网站需要注册公司吗?  Laravel辅助函数有哪些_Laravel Helpers常用助手函数大全  制作公司内部网站有哪些,内网如何建网站?  香港服务器网站卡顿?如何解决网络延迟与负载问题?  利用python获取某年中每个月的第一天和最后一天  Win11怎么修改DNS服务器 Win11设置DNS加速网络【指南】