MYSQL里面插入500万条数据,最优的方式插入

浮生若梦~ 2012-08-21 09:11:36
表结构比较简单id ,name,area,sex,lasttime. innodb collate=utf8_general_ci
...全文
783 15 打赏 收藏 转发到动态 举报
写回复
用AI写文章
15 条回复
切换为时间正序
请发表友善的回复…
发表回复
浮生若梦~ 2012-08-24
  • 打赏
  • 举报
回复
一条条执行是比较慢的。如果直接sql 中while会更快吗
一起混吧 2012-08-24
  • 打赏
  • 举报
回复
你可以先将索引删掉,导入完成后再重建。
浮生若梦~ 2012-08-24
  • 打赏
  • 举报
回复
这样好像很慢,表里面有索引自增id和用户名。
xuzuning 2012-08-24
  • 打赏
  • 举报
回复
mysql> source filename
浮生若梦~ 2012-08-24
  • 打赏
  • 举报
回复
文件是insert into table ()values();insert into..... 省略500万条
xuzuning 2012-08-24
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 的回复:]

如果是sql文件要怎么转成csv。是不是只要转数据不用语句
[/Quote]如果是sql文件,那就直接导入就是了
你最好给个文件的片段
浮生若梦~ 2012-08-24
  • 打赏
  • 举报
回复
如果是sql文件要怎么转成csv。是不是只要转数据不用语句
伴老思源 2012-08-24
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 的回复:]

那个,要怎么用php往文件写入500万条数据呢。有什么好的方法吗
[/Quote]

假设现有数据的表为_T,那么可以直接生成一张表并复制表_T中的数据~

create table _T2 select * from _T order by id limit 0,5000000;
伴老思源 2012-08-24
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 的回复:]

处理成 csv 格式的文件
用 LOAD DATA INFILE 指令加载
[/Quote]
+1
浮生若梦~ 2012-08-24
  • 打赏
  • 举报
回复
那个,要怎么用php往文件写入500万条数据呢。有什么好的方法吗
浮生若梦~ 2012-08-24
  • 打赏
  • 举报
回复
最后的方法分享下:先 生成 以逗号分割,以\t分割,条记录以\r\n分割。
在LOAD DATA INFILE 去掉索引 100万条13s. 500万条1min18s
ws_123456 2012-08-23
  • 打赏
  • 举报
回复
BigDump
浮生若梦~ 2012-08-23
  • 打赏
  • 举报
回复
导入测试数据用的
我达威 2012-08-21
  • 打赏
  • 举报
回复
什么样的文件还是采集的?
xuzuning 2012-08-21
  • 打赏
  • 举报
回复
处理成 csv 格式的文件
用 LOAD DATA INFILE 指令加载

21,887

社区成员

发帖
与我相关
我的任务
社区描述
从PHP安装配置,PHP入门,PHP基础到PHP应用
社区管理员
  • 基础编程社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧