検索

ホームページ  >  に質問  >  本文

python - mysql.connector.errors.InternalError: Unread result found.

import pandas as pd
import mysql.connector as cnmsq

try:
    cnkun = cnmsq.connect(user='root',
                          password='123456',
                          host='127.0.0.1',
                          database='dbkun')
except:
    print('failed connect!')

table = pd.read_excel(r'D:\source.xls')
names = list(table['种名'])
acc_or_syn = [None]*len(table)
acc_family = [None]*len(table)
acc_genus = [None]*len(table)
acc_names = [None]*len(table)
acc_fnames = [None]*len(table)
aos_query = "SELECT is_accepted_name, accepted_id FROM kun_species WHERE species_name=%s"
acc_query = "SELECT species_family, species_genus, species_name, species_full_name FROM kun_species WHERE species_id=%s"
cursor = cnkun.cursor()
for i, name in enumerate(names):
    cursor.execute(aos_query, (name.strip(),))
    for w, s in cursor:
        acc_or_syn[i] = w
        cursor.execute(acc_query, (s,))
        acc_tuple = cursor.fetchone()
        acc_family[i], acc_genus[i], acc_names[i], acc_fnames[i] = acc_tuple

上面这段代码的逻辑是从source.xlsx文件中读取某一列,然后根据该列的每一行字符串从mysql数据中找出该字符串及其对应的值,对于绝大部分source.xlsx列中的字符串,在mysql数据表中都仅有一条记录与之对应,也就是说大多数情况下cursor.execute(aos_query, (name.strip(),))内只有一行记录,但当mysql中遇到执行cursor.execute(aos_query, (name.strip(),))出现多于一行记录时,程序就会出错:

Traceback (most recent call last):
  File "D:\...py", line 43, in <module>
    cursor.execute(acc_query, (s,))
  File "C:\Users\...\Anaconda3\lib\site-packages\mysql\connector\cursor.py", line 476, in execute
    raise errors.InternalError("Unread result found.")
mysql.connector.errors.InternalError: Unread result found.

请问这是什么原因。

PHP中文网PHP中文网2835日前1093

全員に返信(1)返信します

  • 天蓬老师

    天蓬老师2017-04-17 17:27:27

    リーリー

    返事
    0
  • キャンセル返事