MySQL数据导入(学习笔记)

"这篇博客介绍了如何使用MySQL的LOAD DATA INFILE命令导入数据,并处理自增主键问题。在导入前,通过Python的pandas和numpy库对数据进行预处理,将id字段设置为NAN,并保存为CSV文件。在MySQL中,由于sql_mode的限制,需要调整模式以允许导入自增主键。通过set sql_mode=""清除设置,然后导入数据。文章还提供了导入成功后的确认方法。"
摘要由CSDN通过智能技术生成

导入数据用的一般是这个命令:

load data infile '路径' into table 表名 fields terminated by ',' optionally enclosed by '"' ignore 1 rows;

一般情况下我们需要新建立一个表(或者清除原来表里的数据:TRUNCATE TABLE 表名;)然后我这里是对需要用到的数据进行了处理,对所有数据的id进行了NAN处理,我这里用的是pandas和numpy,处理完之后保存。

import pandas as pd
import numpy as np
df = pd.DataFrame(pd.read_csv('路径'))
df['id'] = np.nan
df.to_csv('路径')

接下来是MySQL导入数据可能出现的问题解决;

 MySQL不允许导入自增主键的值,与sql_mode参数有关;
经查询,sql_mode的值为
ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
修改为"" 导入并distinct查询结果  

使用set sql——mode="";再进行show variables like 'sql_mode';

sql_mode理论上只需要改一次,所以剩下的直接load data就可以

 接下来就是导数据,按照上面的命令输入,显示query OK就表示可以。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值