Python:mysql-connector-python查询不到新增数据

查询代码

# -*- coding: utf-8 -*-
import time

import mysql.connector

config = {
    "database": "data",
    "username": "root",
    "password": "123456",
    "host": "127.0.0.1",
    "port": 3306
}

connect = mysql.connector.Connect(**config)
cursor = connect.cursor(dictionary=True)

while True:

    cursor.execute("SELECT * FROM person")
    result = cursor.fetchall()  # fetchall() 获取所有记录

    time.sleep(2)
    print(result)

# 关闭游标和连接
cursor.close()
connect.close()

当执行以上代码时,在MySQL数据库修改数据(增、删、改)没法获取到修改后的数据

翻阅文档10.2.35 MySQLConnection.autocommit Property发现一句话

When the autocommit is turned off, 
you must commit transactions when using transactional storage engines such as InnoDB or NDBCluster.

经测试,以下两个方式都能解决查询新数据的问题

  1. 配置参数autocommit=True
  2. 执行后手动commit

修改后的代码如下

# -*- coding: utf-8 -*-
import time

import mysql.connector

config = {
    "database": "data",
    "username": "root",
    "password": "123456",
    "host": "127.0.0.1",
    "port": 3306,
    "autocommit": True
}

connect = mysql.connector.Connect(**config)
cursor = connect.cursor(dictionary=True)

while True:

    cursor.execute("SELECT * FROM person")
    result = cursor.fetchall()  # 获取所有记录

    time.sleep(2)
    print(result)
    print(connect.in_transaction)

    # 如果不commit,数据库新增、删除、修改的数据没法查询到
    # connect.commit()

# 关闭游标和连接
cursor.close()
connect.close()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值