我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何在Flask中实现数据分组流程详解

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何在Flask中实现数据分组流程详解

【数据库模型类】

class ConColumn(db.Model):
    __tablename__='content_column'
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(50), nullable=False)
    pid = db.Column(db.Integer)
    parent_name = db.Column(db.String(50), nullable=False)
    ......
    # 和文章的关系
    articles = db.relationship('Article', backref="content_article")
class Article(db.Model):
    __tablename__ = 'content_article'
    id = db.Column(db.Integer, primary_key=True)
    #columnId = db.Column(db.String(11), nullable=False)
    photoUrl = db.Column(db.String(300))
    fileUrl = db.Column(db.String(300))
    create_time = db.Column(db.DateTime, default=datetime.now)
    ...... 
    # 外键
    columnId = db.Column(db.Integer, db.ForeignKey("content_column.id"), nullable=False)

想要在flask实现两个表联合查询,得到Article表的id,photoUrl,fileUrl,ConColumn表的name

按照Article的create_time倒排序,该如何写查询?

【循环展示】

目标:同一ConColumn的表的相同的name放在一行显示

2021(ConColumn表的name)

图片1(地址是photoUrl) 图片2(地址是photoUrl) 图片3(地址是photoUrl)

2020(ConColumn表的name)

图片1(地址是photoUrl) 图片2(地址是photoUrl) 图片3(地址是photoUrl)

2016(ConColumn表的name)

图片1(地址是photoUrl) 图片2(地址是photoUrl) 图片3(地址是photoUrl)

【数据库中的数据:】

22 11 学而思 0 ... ...

23 15 TSM 0 ... ...

24 16 CATL 0 ... ...

25 16 锦浪 0 ... ...

字段的顺序依次是id,columnId,title,detail,is_top,photoUrl,fileUrl

class Article(db.Model):
    __tablename__ = 'content_article'
    id = db.Column(db.Integer, primary_key=True)
    ... 
    columnId = db.Column(db.Integer, db.ForeignKey("content_column.id"), nullable=False)
  def findArticleGroup(self, column_id):
        children_ids = [11, 12, 13, 14, 15, 16, 17]
        articles = (
            Article.query.join(ConColumn, Article.columnId == ConColumn.id)
            .filter(Article.columnId.in_(children_ids), Article.is_top == 0)
            .with_entities(Article.id,Article.photoUrl, Article.fileUrl, ConColumn.name)
            #.group_by(ConColumn.name)
            .order_by(Article.create_time.desc())
            .all()
        )

对应的sql

SELECT content_article.id AS content_article_id, content_article.`photoUrl` AS `content_article_photoUrl`, content_article.`fileUrl` AS `content_article_fileUrl`, content_column.name AS content_column_name 
FROM content_article INNER JOIN content_column ON content_article.`columnId` = content_column.id 
WHERE content_article.`columnId` IN (11,12,13,14,15,16,17) AND content_article.is_top = 0 
ORDER BY content_article.create_time DESC

logging.getLogger('sqlalchemy.engine').setLevel(logging.DEBUG) # 将日志级别设置为 debug

【问题】

1.设置日志级别的语句是放在这里吗?然后在哪里查看日志

2.这个分组查询中,符合条件的数据应该是4条,但是分组之后的数据把id=25的数据丢失了,不知什么原因。

【回答】

如果没有在控制台中看到 SQL 语句,那可能是你的日志级别设置过高了。这种情况下,重新设置日志级别即可,例如:

可以在控制台中查看 SQL 语句。关于查询中 id=25 的数据丢失的问题,应该是在分组查询中出了问题。请检查一下在查询的时候,是否漏选了某些条件,是否有其他查询导致该数据被过滤了掉等等。可以将 group_by(ConColumn.name) 语句删除掉试试看是否能查到 id=25 的数据,或者将 group_by 语句修改为 group_by(Article.id),以便更好地定位问题。

import logging
logging.basicConfig()
logging.getLogger('sqlalchemy.engine').setLevel(logging.INFO) # 重新设置为 INFO 级别

这样就可以在控制台输出 SQL 语句了。如果仍然无法输出 SQL 语句,可能是数据库配置方面的问题,你可以查看你使用的数据库的文档,了解更多日志输出配置方面的信息。

【前端(vue)】

  <div v-for="(item, index) in tableData" :key="index">
      <div class="MasonryList-title">{{ item.parentName }}</div>
      <div class="wrapper">
        <div v-for="(file, index) in item.files" :key="index">
          <div class="child">
            <img
              class="imgStyle"
              :class="lazy" data-src="file.categorieIcon"
              @click="getNewsDetail(file.fileUrl)"
            />
          </div>
        </div>
      </div>

到此这篇关于如何在Flask中实现数据分组流程详解的文章就介绍到这了,更多相关Flask实现数据分组内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何在Flask中实现数据分组流程详解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何在Flask中实现数据分组流程详解

在Flask中,数据分组是指将一组数据按照某种方式进行分类,以便更好地对数据进行处理和展示。可以使用Python内置的itertools模块中的groupby方法,或者使用SQL语句中的GROUPBY子句来实现数据分组
2023-05-19

如何在MongoDB中实现数据分页功能

如何在MongoDB中实现数据分页功能概述:在大规模数据的处理过程中,数据分页是一项非常常见且重要的功能。它可以在处理海量数据时,只返回一部分数据,提高性能并降低系统负载。在MongoDB中,实现数据分页功能同样是一项重要的任务。本文将介绍
2023-10-22

如何在AmazonAurora中实现数据的分片和分区

在Amazon Aurora中,数据的分片和分区是通过创建和管理数据库表的方式来实现的。以下是在Amazon Aurora中实现数据的分片和分区的步骤:创建表时使用分区键:在创建表时,可以指定一个或多个列作为分区键。分区键将数据按照指定的列
如何在AmazonAurora中实现数据的分片和分区
2024-04-09

如何在MongoDB中实现数据的实时大数据分析功能

如何在MongoDB中实现数据的实时大数据分析功能引言:随着信息化时代的到来,大数据分析逐渐成为企业和组织管理决策的重要工具。MongoDB作为一款流行的非关系型数据库,具备高性能、高可扩展性和灵活的数据模型等优点,成为了大数据分析的不二选
2023-10-22

如何在MongoDB中实现数据的实时物流追踪功能

如何在MongoDB中实现数据的实时物流追踪功能物流追踪是供应链管理中的重要环节,通过实时追踪货物的位置和状态,能够帮助企业准确把握货物的流动情况,提高物流效率。在实际的物流管理中,MongoDB作为一种高效的非关系型数据库,能够为实时物流
2023-10-22

BIRT中如何根据参数实现动态日期分组

BIRT中如何根据参数实现动态日期分组,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。BIRT一般擅长处理规则一致的数据,若条件不一致的动态运算在报表中是很难实现
2023-06-03

如何在SQL Server中实现和管理数据分发

在SQL Server中,您可以使用以下方法来实现和管理数据分发:使用SQL Server Replication:SQL Server提供了一种内置的数据分发机制,即复制。通过设置发布者、分发者和订阅者,可以将数据从一个数据库实例复制到另
如何在SQL Server中实现和管理数据分发
2024-06-04

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录