首页 / JAVA / java实现sql批量插入参数
java实现sql批量插入参数
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了java实现sql批量插入参数,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2473字,纯文字阅读大概需要4分钟。
内容图文
![java实现sql批量插入参数](/upload/InfoBanner/zyjiaocheng/446/280fc90d2c934bc29ab76f4c9a740c0f.jpg)
需要更新一些不规范的时间格式,如将某个时间格式化为yy-MM-dd,实际上为 yy-MM-dd hh:mm:ss,并且需要提供回滚脚本。
例如:规范化时间的脚本如下:
update test set test_date=substring(account_date,1,10) WHERE test_date>‘2017-06-01 00:00:00‘ AND test_date<‘2017-09-07 00:00:00‘
这个脚本是ok,但执行时受到影响的行数如果有几百条甚至上千条记录的话,回滚脚本怎么写呢?
模板如下:
update test set test_date= ‘‘ where id=‘‘;
1.首先,从test表中查出上述的参数:
select id,test_date from test where test_date>‘2017-06-01 00:00:00‘ AND test_date<‘2017-09-07 00:00:00‘
将结果导入到文本中,名为为param.txt
2.然后运行以下java程序,打印出可执行的回滚脚本
private void insertData() throws IOException{
FileReader reader = new FileReader("D:\\document\\load\\data1.txt");
BufferedReader br = new BufferedReader(reader);
String updateSql="update test set test_date= ‘‘ where id=‘‘;";
String line = null;
Integer count=0;
String[] param=new String[2];
String regexp = "\‘\‘";
while((line = br.readLine()) != null) {
param=line.split("\\\t");
String first=updateSql.replaceFirst(regexp,"\‘"+param[1]+"\‘");
String second=first.replaceFirst(regexp,"\‘"+param[0]+"\‘");
System.out.println(second);
count++;
}
br.close();
reader.close();
}
3.如果行数较多,需要打印到文件中(Console打印的记录数受限的)
private void insertData() throws IOException{
FileReader reader = new FileReader("D:\\document\\load\\data1.txt");
BufferedReader br = new BufferedReader(reader);
StringBuffer sbf=new StringBuffer();
String updateSql="update test set test_date= ‘‘ where id=‘‘;";
String line = null;
Integer count=0;
String[] param=new String[2];
String regexp = "\‘\‘";
while((line = br.readLine()) != null) {
param=line.split("\\\t");
String first=updateSql.replaceFirst(regexp,"\‘"+param[1]+"\‘");
String second=first.replaceFirst(regexp,"\‘"+param[0]+"\‘");
//System.out.println(second);
sbf.append(second).append("\n");
count++;
}
writeFile("D:\\document\\load\\rollback.sql", sbf);
br.close();
reader.close();
}
public void writeFile(String fileName,StringBuffer stf)
throws IOException {
BufferedWriter writer = new BufferedWriter(new FileWriter(fileName));
writer.write(stf.toString());
writer.close();
}
java实现sql批量插入参数
标签:打印 and integer 规范化 回滚 java实现 string buffere sele
本文系统来源:https://blog.51cto.com/15015181/2556636
内容总结
以上是互联网集市为您收集整理的java实现sql批量插入参数全部内容,希望文章能够帮你解决java实现sql批量插入参数所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。