一、报错原因
关闭了数据库连接之后又使用数据库操作(数据库连接已过期,导致后续的数据库操作不能正常使用)
二、解决方案
1. 重新建立数据库连接;
2. 确认数据库使用完毕之后,再关闭连接。
三、举个栗子
# 连接数据库
data_return = cloudSQL_connect(config)
db, cursor = data_return[0], data_return[1]
sql = '''SELECT device_id from table_name GROUP BY device_id '''
cursor.execute(sql)
device_id_set = cursor.fetchall()
db.commit()
# 读取数据
for device_id in device_id_set:
print(device_id)
sql_2 = '''SELECT * from table_name where device_id = '%s' ''' % device_id[0]
cursor.execute(sql_2)
dataset = cursor.fetchall()
db.commit()
db.close() ####### 这句出错~~~~~~~~~
如上,db.close() 写在了 for 循环里面,但 pymysql.connect() 在 for 循环之外,所以关闭 db 之后无法再使用数据库!
解决办法:将 db.close() 写在 for 循环结束之后即可~~~
# 连接数据库
data_return = cloudSQL_connect(config)
db, cursor = data_return[0], data_return[1]
sql = '''SELECT device_id from table_name GROUP BY device_id '''
cursor.execute(sql)
device_id_set = cursor.fetchall()
db.commit()
# 读取数据
for device_id in device_id_set:
print(device_id)
sql_2 = '''SELECT * from table_name where device_id = '%s' ''' % device_id[0]
cursor.execute(sql_2)
dataset = cursor.fetchall()
db.commit()
db.close()