(20200407已解决)(pymysql.err.InternalError) (1050, "Table 'table_name' already exists")

  • 问题描述

    pd.io.sql.to_sql存入数据时,出现如题错误。

    在使用pd.io.sql.to_sql之前,table_name已经建好,初次调用pd.io.sql.to_sql会报错,二次及以后调用pd.io.sql.to_sql并不会再报错。

  • 解决方案

    仔细查看过程,会发现第一次调用pd.io.sql.to_sql包含两个过程:

    1. 创建表
    2. 存入数据。

    这里涉及到数据库连接的先后顺序问题。

    pd.io.sql.to_sql所使用的连接是在创建表之前建立的,因此它不知道数据库中已经有表table_name了,所以pd.io.sql.to_sql先创建表,创建过程中发现与已有表重复就出现了如题问题。

    可以在使用pd.io.sql.to_sql之前,重新刷新一下所用的conn,就能解决这个问题,准确说是在另一个创建表的程序创建完成之后就刷新一下pd.io.sql.to_sql所需要用到的conn

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值