首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何在MySQL中进行批量插入

如何在MySQL中进行批量插入
EN

Stack Overflow用户
提问于 2011-04-03 09:14:41
回答 4查看 313K关注 0票数 173

我有1-多条记录需要输入到一个表中。在查询中执行此操作的最佳方法是什么?我是否应该只做一个循环,并在每次迭代中插入一条记录?还是有更好的方法?

EN

回答 4

Stack Overflow用户

发布于 2012-05-31 07:18:17

大多数情况下,您不是在MySQL客户端中工作,而是应该使用适当的API一起批处理插入。

例如在JDBC中:

代码语言:javascript
复制
connection con.setAutoCommit(false); 
PreparedStatement prepStmt = con.prepareStatement("UPDATE DEPT SET MGRNO=? WHERE DEPTNO=?");
prepStmt.setString(1,mgrnum1);                 
prepStmt.setString(2,deptnum1);
prepStmt.addBatch();

prepStmt.setString(1,mgrnum2);                        
prepStmt.setString(2,deptnum2);
prepStmt.addBatch();

int [] numUpdates=prepStmt.executeBatch();

http://publib.boulder.ibm.com/infocenter/db2luw/v8/index.jsp?topic=/com.ibm.db2.udb.doc/ad/tjvbtupd.htm

票数 25
EN

Stack Overflow用户

发布于 2012-01-05 16:47:59

代码语言:javascript
复制
Insert into table(col1,col2) select col1,col2 from table_2;

请参考MySQL documentation on INSERT Statement

票数 10
EN

Stack Overflow用户

发布于 2013-03-19 13:49:02

Load data infile是一个更好的选择,但是一些服务器如godaddy在共享主机上限制了这个选项,所以只剩下两个选项,然后一个是在每次迭代或批量插入时插入记录,但是批量插入有它的字符数限制如果你的查询超过mysql中设置的字符数,那么你的查询将崩溃,所以我建议使用批量插入在块中插入数据,这将最小化与幸运的database.best建立的连接的数量

票数 9
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5526917

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档