开发者社区> 问答> 正文

mysql数据库mysql.connector.errors.InternalError: Unread result found错误

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

展开
收起
蛮大人123 2016-02-08 17:23:50 5398 0
1 条回答
写回答
取消 提交回答
  • 我说我不帅他们就打我,还说我虚伪

    for i, name in enumerate(names):

    cursor.execute(aos_query, (name.strip(),))  // 假如这里读到多行数据,结果集缓存在某个地方
    // 下面从游标中读取数据,相当于执行了fetchone,如果有多条数据,那游标对应位置之后还有数据
    for w, s in cursor:   // 可以改为**for w, s in cursor.fetchall()**返回所有数据
        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
    2019-07-17 18:39:50
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
搭建电商项目架构连接MySQL 立即下载
搭建4层电商项目架构,实战连接MySQL 立即下载
PolarDB MySQL引擎重磅功能及产品能力盛大发布 立即下载

相关镜像