python - 在不关闭连接的情况下在 python 中获取更新的 MySQL 表条目

标签 python mysql sql

我有 2 个 python 程序在运行。 Script1 定期将条目写入表,Script2 从同一个 MySQL 表中读取。两者同时运行。 Script2 必须获取表的最后一个(最新添加的)条目。

现在,问题是 Script1 完美地向表中添加条目,但 Script2 无法每次都读取最新的条目。它只在我阅读后关闭连接时读取最新的条目,并在我想再次阅读时重新打开它。

这是唯一可以采用的方法吗?有没有办法无需每次都关闭和打开连接来获取更新的值?访问不断更新的数据库时,程序员遵循的最佳实践是什么?

更详细:

下面的代码工作正常,但无法显示更新后的值。它第一次成功显示了最后一个条目,但接下来几次调用 readComm() 时,尽管表已更新,但仍会再次显示相同的条目。

import MySQLdb
import time

db = MySQLdb.connect("localhost", "root", "abc", "abc")
cursor=db.cursor()

def readComm():
    sql = "SELECT * FROM my_table ORDER BY id DESC LIMIT 1;"
    try:
        cursor.execute(sql)
        # Fetch all the rows in a list of lists.
        results = cursor.fetchall()
        print '~~~~', results
    except:
        print "Error! Unable to fetch data" 
    return
for i in range(5):
    readComm()
    time.sleep(10)

如果我修改它,代码会显示更新的值,以便在我每次进入和退出 readComm() 时分别打开和关闭数据库。

最佳答案

这只是因为事务中的读取隔离。在每个循环之后执行 db.commit()

关于python - 在不关闭连接的情况下在 python 中获取更新的 MySQL 表条目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24415699/

相关文章:

Python TKinter 下拉菜单问题

python - 从 python 中运行 python 脚本并捕获异常

php while循环只显示跨多个表的mysql查询的一个结果

mysql - 为 MySQL 选择查询自定义排序依据

sql - 我如何获得每个国家/地区的最大值

python - 如何使用 sklearn 预处理器

python - BeautifulSoup4导入错误

mysql - 在 MySQL 中生成唯一的 10 个字符的字母数字哈希

java - 我的小程序无法连接到 Servlet 和传输数据

sql - Redshift COPY 命令返回 STL_load_error 1205 无效的日期格式 - 长度必须为 10 或更多