jdbc批量执行SQL insert 操作
- package com.file;
- import java.io.BufferedReader;
- import java.io.FileReader;
- import java.util.ArrayList;
- public class ResolvFile {
- public static String readFileContent(String filepath) {
- //1.读取每一行记录,保存到List中
- ArrayList<String> records = new ArrayList<String>();
- try {
- BufferedReader br = new BufferedReader(new FileReader(filepath));
- String aRecord;
- while((aRecord = br.readLine())!=null){
- records.add(aRecord);//把读取到的每一行记录保存到List中
- }
- br.close();//用完以后关闭流
- } catch (Exception e) {
- e.printStackTrace();
- }
- //2.处理每一条记录成SQL语句或保存为对象(a.去掉字段前后的分号b.拼接成SQL或者保存为对象)
- ArrayList<String> recordList = new ArrayList<String>();//用于保存生成的SQL或对象
- for(int i = 0;i<records.size();i++) {
- String record = records.get(i);
- String[] recArray = minusQuotation(record.split(","));
- //拼接SQL语句或保存为对象
- String recordSql = getRecordSql(recArray);
- if (null!=recordSql) {
- recordList.add(recordSql);
- }
- }
- //3.批量执行SQL或保存对象
- batchExecuteSql(recordList);
- return null;
- }
- public static int batchExecuteSql(ArrayList<String> sqlList) {
- System.out.println("接下来可以执行SQL语句或保存对象");
- System.out.println("========批量执行SQL语句==========");
- System.out.println("将所有语句加入到Statment stat中");
- for (int i = 0;i<sqlList.size();i++) {
- String string = sqlList.get(i);
- System.out.println("通过stat.addBatch(sql)来加入语句"+i+": '"+string+"'");
- }
- System.out.println("通过stat.executeBatch()来执行所有的SQL语句");
- System.out.println("========批量执行SQL语句结束==========");
- //int count = stat.executeBatch();
- //return count;//返回执行的语句数量
- return sqlList.size();
- }
- //生成每条记录的SQL
- public static String getRecordSql(String[] recArray) {
- if (null==recArray) {
- return null;
- }
- String recordSql = "insert into tablename (sms,no,time) values('"+recArray[0]+"','"+recArray[2]+"','"+recArray[5]+"')";
- return recordSql;
- }
- /**
- * 去掉数组中每一个元素的开头和结尾的引号
- * @param recArray 要处理的数组
- * @return 处理后的数组
- */
- public static String[] minusQuotation(String[] recArray) {
- for (int i = 0; i < recArray.length; i++) {
- String str = recArray[i];
- if (null!=str) {
- if(str.indexOf( "\"")==0)
- str = str.substring(1,str.length());//去掉开头的分号
- if(str.lastIndexOf("\"")==(str.length()-1))
- str = str.substring(0,str.length()-1); //去掉最后的分号
- }
- recArray[i] = str;
- }
- return recArray;
- }
- public static void main(String[] args) {
- String filepath = "E:\\sxySMS\\smstest.txt";
- readFileContent(filepath);
- }
- }
jdbc批量执行SQL insert 操作的更多相关文章
- JDBC 复习4 批量执行SQL
1使用jdbc进行批量执行SQL在实际的项目开发中,有时候需要向数据库发送一批SQL语句执行,这时应避免向数据库一条条的发送执行,而应采用JDBC的批处理机制,以提升执行效率. package dbe ...
- JDBC连接MYSQL,批量执行SQL语句或在执行一个SQL语句之前执行一个SQL语句
conn = MysqlJdbcUtils.getConnection(); Statement ps=conn.createStatement(); ps.addBatch("trunca ...
- mysql数据库批量执行sql文件对数据库进行操作【windows版本】
起因: 因工作需要,在本机测试环境升级mysql数据库,需逐条执行mysql数据库的sql文件对数据库进行升级,因此找了些关于mysql的文章,对批量升级数据库所需的sql文件进行升级. 整理思路: ...
- JDBC批量执行executeBatch
JDBC事务 在数据库中,所谓事务是指一组逻辑操作单元,使数据从一种状态变换到另一种状态.为确保数据库中数据的一致性,数据的操纵应当是离散的成组的逻辑单元:当它全部完成时,数据的一致性可以保持,而当这 ...
- Java JDBC下执行SQL的不同方式、参数化预编译防御
相关学习资料 http://zh.wikipedia.org/wiki/Java数据库连接 http://lavasoft.blog.51cto.com/62575/20588 http://blog ...
- SQL*PLUS中批量执行SQL语句
SQL*PLUS中批量执行SQL语句 今天由于工作的需要,要在CMD中批量执行大量的SQL语句,对于Oracle学习还处在入门阶段的我,只能硬着头皮到处去寻找资料(主要是网络资料,也包括自己的电子书) ...
- 批量执行sql语句
基本使用 $sqls="sql语句1;sql语句2;sql语句n"; 或 $sqls="insert into xx;"; $sqls.="inse ...
- 批量执行SQL文件
原文:批量执行SQL文件 摘要:很多时候我们在做系统升级时需要将大量的.sql文件挨个执行,十分不方便.而且考虑到执行顺序和客服的操作方便性,能不能找到一种简单的方法来批量执行这些sql文件呢? 主要 ...
- PHP mysqli 增强 批量执行sql 语句的实现代码
本篇文章介绍了,在PHP中 mysqli 增强 批量执行sql 语句的实现代码.需要的朋友参考下. mysqli 增强-批量执行sql 语句 <?php //mysqli 增强-批量执行sql ...
随机推荐
- UpdateData使用说明
UpdateData() MFC的窗口函数,下面是MSDN的说明: Call this member function to initialize data in a dialog box, or t ...
- PHP中字符串转换为数值 可能会遇到的坑
今天看到一个老外最喜欢的一段代码 <?php $string = 'zero'; $zero = 0; echo ($string == $zero) ? 'Why? Just why?!' : ...
- Perl 之 use(), require(), do(), %INC and @INC
来源: http://www.cnblogs.com/itech/archive/2013/03/12/2956185.html 转自:http://perl.apache.org/docs/gene ...
- Inno Setup入门(十九)——Inno Setup类参考(5)
: Install Setup 2013-02-02 11:29 377人阅读 评论(0) 收藏 举报 单选按钮 单选按钮在安装中也很常见,例如同一个程序可以选择安装不同的性质的功能,例如选择32位或 ...
- Puppent 基本使用方法
简单的文件配置 master端 vim /etc/puppet/manifests/site.pp ###########################内容如下 node default{ file ...
- 基于Win32 SDK实现的一个简易线程池
利用C++实现了一个简易的线程池模型(基于Win32 SDK),方便使用多线程处理任务.共包含Thread.h.Thread.cpp.ThreadPool.h.ThreadPool.cpp四个源文件. ...
- Win7 “Bluetooth设置”对话框无法打开,及无法查找到设备
方法是在百度上找到的,试用成功. 1.打开开始菜单中的运行选项,然后在对话框中输入services.msc,回车打开服务界面: 2.然后在弹出来的服务窗口中查找到Bluetooth Support S ...
- http & json
TCP(传输层协议) (1) 面向连接 (2) 可靠的 (3) 基于字节流的 连接建立阶段: 客户端 ------->SYN 服务端(服务器被动打开) 客 ...
- linux视频学习3(linux安装,shell,tcp/ip协议,网络配置)
linux系统的安装: 1.linux系统的安装方式三种: 1.独立安装linux系统. 2.虚拟机安装linux系统. a.安装虚拟机,基本是一路点下去. b.安装linux. c.linux 安装 ...
- POJ 2082Lost Cows<>
题意: 给出一个序列a[1....n],a[i]代表在0....i-1中比a[i]小的个数. 求出这个序列. 思路: 1:暴力. #include<cstdio> #include< ...