”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 为什么 Python 循环中的后续查询会从 MySQL 数据库返回相同的数据?

为什么 Python 循环中的后续查询会从 MySQL 数据库返回相同的数据?

发布于2024-11-10
浏览:682

Why Do Subsequent Queries in a Python Loop Return the Same Data from a MySQL Database?

使用 Python 查询从 MySQL 检索动态数据

当从 Python 定期查询快速变化的 MySQL 数据库时,您可能期望基于循环的一致获取最新数据的方法。但是,您可能会遇到重复返回相同数据的情况。

这个问题源于MySQL的默认隔离级别REPEATABLE READ。在此级别下,事务内的读取将使用事务开始时存在的数据快照。同一事务中的后续查询将从该快照中读取而不是更新它。

要解决此问题,您需要在每次查询后提交连接,以确保下一个事务将检索最新数据。以下是修改 Python 代码的方法:

# Main loop
while True:

    # SQL query
    sql = "SELECT * FROM table"

    # Read the database, store as a dictionary
    mycursor = mydb.cursor(dictionary=True)
    mycursor.execute(sql)

    # Store data in rows
    myresult = mycursor.fetchall()

    # Transfer data into list
    for row in myresult:
        myList[int(row["rowID"])] = (row["a"], row["b"], row["c"])

        print(myList[int(row["rowID"])])

    # Commit !
    mydb.commit()
    print("---")
    sleep (0.1)

通过在每个查询后添加 mydb.commit(),您可以强制 MySQL 提交事务并更新快照。这允许后续查询访问最新数据。

最新教程 更多>
  • 如何在 Golang Web 服务器中流式传输 MP4 视频?
    如何在 Golang Web 服务器中流式传输 MP4 视频?
    GoLang Web 服务器流视频问:Golang Web 服务器配置为服务 HTML、CSS、JavaScript 和图像失败尝试流式传输 MP4 视频。该问题是由于处理大型视频文件而引起的。 Chrome 要求服务器支持超过一定大小的视频的 Range 请求,但提供的代码没有解决这个问题。通过实...
    编程 发布于2024-11-14
  • Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta:列偏移的删除和恢复Bootstrap 4 在其 Beta 1 版本中引入了重大更改柱子偏移了。然而,随着 Beta 2 的后续发布,这些变化已经逆转。从 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    编程 发布于2024-11-14
  • 如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    MySQL配置不正确:相对路径的问题在Django中运行python manage.py runserver时,可能会遇到以下错误:ImproperlyConfigured: Error loading MySQLdb module: dlopen(/Library/Python/2.7/site-...
    编程 发布于2024-11-14
  • 如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 识别今天生日的用户使用 MySQL 确定今天是否是用户的生日涉及查找生日匹配的所有行今天的日期。这可以通过一个简单的 MySQL 查询来实现,该查询将存储为 UNIX 时间戳的生日与今天的日期进行比较。以下 SQL 查询将获取今天有生日的所有用户: FROM USERS ...
    编程 发布于2024-11-14
  • CSS 中的“display: table-column”实际上做了什么?
    CSS 中的“display: table-column”实际上做了什么?
    CSS“display: table-column”应该如何工作?在 HTML 中,表格由行组成,每行含有细胞。 CSS 扩展了这个概念,允许设计者定义特定的行和列布局。虽然“display: table-row”和“display: table-cell”很简单,但“display: table-...
    编程 发布于2024-11-14
  • Babel 6 如何以不同的方式处理默认导出?
    Babel 6 如何以不同的方式处理默认导出?
    重大变更:Babel 6 导出默认行为随着 Babel 6 的发布,默认导出的处理方式发生了重大变化。虽然 Babel 之前添加了 module.exports = Exports["default"] 行,但此功能已被删除。此修改需要更改模块导入语法。以前,使用旧语法的代码:v...
    编程 发布于2024-11-14
  • 掌握 Next.js 中的 SSR:如何提升 SEO 和用户体验
    掌握 Next.js 中的 SSR:如何提升 SEO 和用户体验
    SSR(服务器端渲染)是 Next.js 中生成页面的另一种方法。在本文中,我想解释什么是 SSR、它是如何工作的,以及如何在 Next.js 项目的 Page Router 和 App Router 中实现它。 什么是SSR? SSR是一种在用户发出请求后生成静态页面(或预渲染页面...
    编程 发布于2024-11-14
  • 为什么 PHP 5.2 不允许抽象静态类方法?
    为什么 PHP 5.2 不允许抽象静态类方法?
    PHP 5.2 严格模式:为什么不允许抽象静态类方法?在 PHP 5.2 中,启用严格警告可能会触发熟悉的警告:“静态函数不应该是抽象的”。此警告源于 PHP 5.2 中引入的一项更改,该更改不允许抽象静态类方法。原因:历史监督PHP 5.2 最初缺乏后期静态绑定,使抽象静态函数变得无用。由于抽象静...
    编程 发布于2024-11-14
  • 如何为 10 个连续点的每段绘制不同颜色的线?
    如何为 10 个连续点的每段绘制不同颜色的线?
    用不同的颜色绘制一条线问题陈述给定两个列表,latt和lont,目标是绘制一条线,其中每个列表10 个连续点的线段以不同的方式表示color.解决方案线段数量有限如果线段数量较少,例如10个或更少,一个简单的方法就是使用循环以唯一的颜色绘制每个段。import numpy as np import ...
    编程 发布于2024-11-14
  • 如何在 MySQL 中根据计数过滤数据而不使用嵌套 SELECT?
    如何在 MySQL 中根据计数过滤数据而不使用嵌套 SELECT?
    MySQL - 在 WHERE 子句中使用 COUNT(*)用户在尝试使用 WHERE 子句中的 COUNT(*) 函数过滤 MySQL 中的数据时遇到了挑战WHERE 子句。他们寻求一种有效的方法来完成此任务,而不使用嵌套 SELECT 语句,因为它会消耗大量资源。用户提供了以下伪代码来说明他们期...
    编程 发布于2024-11-14
  • 如何在 Python 中按名称访问 SQL 结果列值?
    如何在 Python 中按名称访问 SQL 结果列值?
    在 Python 中按列名称访问 SQL 结果列值处理数据库中的大量列时,依赖于列索引数据检索可能会变得很麻烦。本文通过提供一种在 Python 中使用列名称检索 SQL 结果列值的方法来解决对更直观方法的需求。解决方案:利用 DictCursor Python 的 MySQLdb 模块提供了 Di...
    编程 发布于2024-11-14
  • 除了“if”语句之外:还有哪些地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    除了“if”语句之外:还有哪些地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    无需强制转换即可上下文转换为 bool您的类定义了对 bool 的显式转换,使您能够在条件语句中直接使用其实例“t”。然而,这种显式转换提出了一个问题:“t”在哪里可以在不进行强制转换的情况下用作 bool?上下文转换场景C 标准指定了四种值可以根据上下文转换为的主要场景bool:语句:if、whi...
    编程 发布于2024-11-14
  • 何时使用 Django ORM 的 select_lated 与 prefetch_lated?
    何时使用 Django ORM 的 select_lated 与 prefetch_lated?
    Django ORM 的 select_lated 和 prefetch_lated 之间的区别在 Django ORM 中,select_lated 和 prefetch_lated 方法在管理数据库查询中的关系方面具有不同的用途。select_latedDjango的select_lated方法...
    编程 发布于2024-11-14
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2024-11-14
  • 在 Go 中使用 WebSocket 进行实时通信
    在 Go 中使用 WebSocket 进行实时通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    编程 发布于2024-11-13

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3