‘壹’ oracle用insert怎么分批插入数据
insert into 目标表 select * from 数据源表 where rownum >= 1 and rownum <=100;
使用rownum来控制每批插入数据的数量。
‘贰’ java 数据分批插入
importjava.util.ArrayList;
importjava.util.List;
publicclassFenDuan{
/**
*@paramargs
*/
publicstaticvoidmain(String[]args){
//1.总记录数
List<String>oldList=newArrayList<String>();
for(inti=0;i<1045;i++){
oldList.add((i+1)+"");
}
//2.分页数据信息
inttotalSize=oldList.size();//总记录数
intpageSize=10;//每页N条
inttotalPage=totalSize/pageSize;//共N页
if(totalSize%pageSize!=0){
totalPage+=1;
if(totalSize<pageSize){
pageSize=oldList.size();
}
}
System.out.println("循环保存的次数:"+totalPage);//循环多少次
for(intpageNum=1;pageNum<totalPage+1;pageNum++){
intstarNum=(pageNum-1)*pageSize;
intendNum=pageNum*pageSize>totalSize?(totalSize):pageNum*pageSize;
System.out.println("起始:"+starNum+"-"+endNum);
Stringstr="";
for(inti=starNum;i<endNum;i++){
str+=oldList.get(i)+"";
}
System.out.println("第"+pageNum+"批:"+str);
}
}
}
这个只是一个思路
‘叁’ java 如何批量插入数据
通过jdbc就可以执行批量插入了。
以下案例:
1、逐条执行10万次
2、分批执行将10万分成m批,每批n条,分多种分批方案来执行。
/**
* 批处理执行
*
* @param m 批次
* @param n 每批数量
* @throws Exception 异常时抛出
*/
public static void testInsertBatch(int m, int n) throws Exception {
init(); //初始化环境
Long start = System.currentTimeMillis();
for (int i = 0; i < m; i++) {
//从池中获取连接
Connection conn = myBroker.getConnection();
Statement stmt = conn.createStatement();
for (int k = 0; k < n; k++) {
String sql = "\n" +
"insert into testdb.tuser \n" +
"\t(name, \n" +
"\tremark, \n" +
"\tcreatetime, \n" +
"\tupdatetime\n" +
"\t)\n" +
"\tvalues\n" +
"\t('" + RandomToolkit.generateString(12) + "', \n" +
"\t'" + RandomToolkit.generateString(24) + "', \n" +
"\tnow(), \n" +
"\tnow()\n" +
")";
//加入批处理
stmt.addBatch(sql);
}
stmt.executeBatch(); //执行批处理
stmt.close();
myBroker.freeConnection(conn); //连接归池
}
Long end = System.currentTimeMillis();
System.out.println("批量执行" + m + "*" + n + "=" + m * n + "条Insert操作,共耗时:" + (end - start) / 1000f + "秒!");
}
‘肆’ 数据库数据如何批量插入
通过export,import。 可以写SQL脚本,将insert语句在脚本中编辑好,之后执行。
‘伍’ 如何快速在单元格里批量插入不同的数据
目前看题主这边规律是每4进一个5 开头是字母后面接数字,按这个规律可以先在A列下面写入你要加的数据,然后A列做个升序 试试
‘陆’ 数据库如何批量插入数据
解决方法:
添加事务处理,把5000条插入作为一个事务
dataBase.beginTransaction(); //手动设置开始事务
//数据插入操作循环
dataBase.setTransactionSuccessful(); //设置事务处理成功,不设置会自动回滚不提交
dataBase.endTransaction(); //处理完成
将数据库“倒出来”:
sqlite3 film.db ".mp" > output.sql
利用输出的资料,建立一个一模一样的数据库(加上以上指令,就是标准的SQL数据库
备份了):
sqlite3 film.db < output.sql
在大量插入资料时,你可能会需要先打这个指令:
begin;
插入完资料后要记得打这个指令,资料才会写进数据库中:
commit;
‘柒’ java 怎么把5万条数据分批插入数据到mysql,之前插1,2万没事, 多了就内存溢出
你的事务控制问题。
大量数据插入的时候,可以将数据量分批,每次事务提交一批。
例如:
con.setAutoCommit(false);// 更改JDBC事务的默认提交方式
Statement stmt = conn.createStatement();
// 第一批 省略n条
stmt.addBatch("insert into dept values (52,'a','aa')");
stmt.addBatch("insert into dept values (53,'b','bb')");
stmt.addBatch("insert into dept values (54,'c','cc')");
stmt.executeBatch();
con.commit();//提交JDBC事务
stmt.close();
// 第二批 省略n条
stmt = conn.createStatement();
stmt.addBatch("insert into dept values (52,'a','aa')");
stmt.addBatch("insert into dept values (53,'b','bb')");
stmt.addBatch("insert into dept values (54,'c','cc')");
stmt.executeBatch();
con.commit();//提交JDBC事务
stmt.close();
// 第n批
。。。。。。
con.setAutoCommit(true);// 恢复JDBC事务的默认提交方式
conn.close();
‘捌’ 如何批量向word表格中插入数据
1.点击插入
2.选择对象
3.选择新建
4.点击Microsoft
Excel
工作表
5.点击确定
你就可以像编辑Excel表格一样编辑这个表格了