我有1多条记录需要输入到一个表中。在查询中最好的方法是什么?我应该做一个循环,每次迭代插入一条记录吗?还是有更好的办法?
xyhw6mcr1#
大多数情况下,您不是在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
uemypmqf2#
mysql允许您一次插入多行insert manual
alen0pnh3#
来自mysql手册使用值语法的insert语句可以插入多行。为此,请包含多个列值列表,每个列值用括号括起来,并用逗号分隔。例子:
INSERT INTO tbl_name (a,b,c) VALUES(1,2,3),(4,5,6),(7,8,9);
bjg7j2ky4#
Insert into table(col1,col2) select col1,col2 from table_2;
请参阅有关insert语句的mysql文档
fjaof16o5#
加载数据填充查询是一个更好的选择,但是像godaddy这样的服务器在共享主机上限制了这个选项,所以只剩下两个选项,一个是在每次迭代或批插入时插入记录,但是批插入有它的字符数限制如果你的查询超过mysql中设置的字符数,那么你的查询就会崩溃,所以我建议用批插入的方式插入数据,这样可以减少与数据库建立连接的次数。祝你们好运
5条答案
按热度按时间xyhw6mcr1#
大多数情况下,您不是在mysql客户机中工作,应该使用适当的api将插入批处理在一起。
e、 g.在jdbc中:
http://publib.boulder.ibm.com/infocenter/db2luw/v8/index.jsp?topic=/com.ibm.db2.udb.doc/ad/tjvbtupd.htm
uemypmqf2#
mysql允许您一次插入多行insert manual
alen0pnh3#
来自mysql手册
使用值语法的insert语句可以插入多行。为此,请包含多个列值列表,每个列值用括号括起来,并用逗号分隔。例子:
bjg7j2ky4#
请参阅有关insert语句的mysql文档
fjaof16o5#
加载数据填充查询是一个更好的选择,但是像godaddy这样的服务器在共享主机上限制了这个选项,所以只剩下两个选项,一个是在每次迭代或批插入时插入记录,但是批插入有它的字符数限制如果你的查询超过mysql中设置的字符数,那么你的查询就会崩溃,所以我建议用批插入的方式插入数据,这样可以减少与数据库建立连接的次数。祝你们好运