如何在MySQL中进行批量插入

时间:2011-04-03 01:14:41

标签: mysql sql database insert

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

5 个答案:

答案 0 :(得分:261)

来自MySQL manual

  

使用VALUES的INSERT语句   语法可以插入多行。去做   这个,包括多个列列表   每个值都包含在内   括号并用逗号分隔。   例如:

INSERT INTO tbl_name (a,b,c) VALUES(1,2,3),(4,5,6),(7,8,9);

答案 1 :(得分:22)

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

E.g。在JDBC中:

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

答案 2 :(得分:6)

Insert into table(col1,col2) select col1,col2 from table_2;

请访问:http://dev.mysql.com/doc/refman/5.5/en/insert.html

答案 3 :(得分:5)

加载数据infile查询是更好的选择,但像godaddy这样的服务器在共享主机上限制了这个选项,因此,只有两个选项,然后一个是每次迭代或批量插入时插入记录,但批量插入有其限制的字符,如果你的查询超过了mysql中设置的这个字符数,那么你的查询就会崩溃,所以我建议用数组插入数据插入数据块,这样可以最大限度地减少与database.best运气员建立的连接数

答案 4 :(得分:2)

mysql允许您一次插入多行INSERT manual