java处理较大数据量到mysql
1、 jdbd采用批处理插入大量数据,速度还是相当的慢,一个拥有一个自增字段、三个字符串字段的表,往里面插入1W条数据消耗一分多钟。代码如下: public class DBbatchdeal {/** * * @param conn jdbc链接 * @param tableName 表明 * @param lists 数据集 * @
1、 jdbd采用批处理插入大量数据,速度还是相当的慢,一个拥有一个自增字段、三个字符串字段的表,往里面插入1W条数据消耗一分多钟。代码如下:
<span>public class DBbatchdeal { /** * * @param conn jdbc链接 * @param tableName 表明 * @param lists 数据集 * @param n 每行字段个数 出去自增字段 * @param flag 第一列是否自增字段 * @return 是否成功 */ public boolean deal(Connection conn,String tableName,ArrayList<String[]> lists ,int n,boolean flag){ StringBuffer sql = new StringBuffer(); sql.append("insert into ").append(tableName) .append(" values("); sql=(flag==true?sql.append("null ,"):sql); for(int i=0;i<n-1;i++){ sql.append("?, "); } sql.append("?);"); int size=lists.size(); int m= (true==flag?n-1:n); PreparedStatement preStmt=null; long a=System.currentTimeMillis(); try { preStmt = conn.prepareStatement(sql.toString(),ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_READ_ONLY); for(int j=0;j<size;j++){ String[] str=lists.get(j); for(int k=0;k<n;k++){ preStmt.setString(k+1, str[k]); } preStmt.addBatch(); if(j%100==0){ preStmt.executeBatch(); preStmt.clearBatch(); } } preStmt.executeBatch(); } catch (SQLException e) { e.printStackTrace(); }finally{ try { if(null!=preStmt){ preStmt.close(); } } catch (SQLException e) { e.printStackTrace(); } } long b=System.currentTimeMillis(); System.out.println("插入"+size+"条数据所需要的时间:"+(b-a)); return true; } public static void main(String[] args) throws ClassNotFoundException, SQLException { Class.forName("com.mysql.jdbc.Driver"); Connection conn=DriverManager.getConnection("jdbc:mysql://ip***/db", "root", "pwd"); DBbatchdeal deal=new DBbatchdeal(); ArrayList<String[]> lists =new ArrayList<String[]>(); for(int i=0;i<10000;i++){ String[] str={"1307"+i,"passwd"+i,"20130709121212"}; lists.add(str); } deal.deal(conn, "testTable", lists, 3, true); } } </span>
2、因为上面的方法处理的较慢,又想了个较为麻烦点儿的方式,用mysql的load data来导入数据。具体就是写段导入数据的脚本用java来执行,测试了下1w条记录插入的时间还是相当短的。
结果如下:
Java2Sh内容如下:
<span>import java.io.BufferedWriter; import java.io.File; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.OutputStream; import java.io.OutputStreamWriter; import java.io.Writer; public class Java2Sh { /** * 对文件进行赋权 * @param infile 文件全路径 * @return runtime执行返回码 */ public int chmodrun(String infile) { int retCode = 0; try { Runtime rtime = Runtime.getRuntime(); Process child = rtime.exec("chmod 777 " +infile); retCode=child.waitFor(); System.out.println("chmod :"+retCode); } catch (Exception e) { System.out.println("chmod failed "+infile); e.printStackTrace(); } return retCode; } /** *执行脚本文件 * @param infile 文件全路径 * @return runtime执行返回码 */ public int shellFile(String infile) { int retCode = 0; try { Runtime rtime = Runtime.getRuntime(); Process child = rtime.exec("sh " +infile); retCode=child.waitFor(); System.out.println("shell file :"+retCode); } catch (Exception e) { System.out.println("shell file failed "+infile); e.printStackTrace(); } return retCode; } public void writeData() throws IOException{//生成mysql2.txt String str="13311122,passwds,20130710235959"; BufferedWriter out =new BufferedWriter(new OutputStreamWriter(new FileOutputStream(new File("D:\\mysql2.txt")))); for(int i=0;i<10000;i++){ out.write(str); out.write("\n"); } out.flush(); out.close(); } public static void main(String[] args) throws IOException { Java2Sh j2=new Java2Sh(); long a=System.currentTimeMillis(); j2.chmodrun("/shh.sh"); j2.shellFile("/shh.sh"); long b=System.currentTimeMillis(); System.out.println("==========="+(b-a)); // j2.writeData(); } } </span>
其中shh.sh内容为:
mysql -h localhost -u root -ppwd < /loaddata.sql > /dblog
loaddata.sql内容为:
use dbname;
LOAD DATA INFILE '/mysql2.txt' INTO TABLE testTable FIELDS TERMINATED BY ',' (cardnum,cardpwd,times);
commit;
介于个人水平,贴出来仅供参考,欢迎告诉我更简便高效的方式,先谢过了。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

在MySQL中,添加字段使用ALTERTABLEtable_nameADDCOLUMNnew_columnVARCHAR(255)AFTERexisting_column,删除字段使用ALTERTABLEtable_nameDROPCOLUMNcolumn_to_drop。添加字段时,需指定位置以优化查询性能和数据结构;删除字段前需确认操作不可逆;使用在线DDL、备份数据、测试环境和低负载时间段修改表结构是性能优化和最佳实践。

在macOS上安装MySQL可以通过以下步骤实现:1.安装Homebrew,使用命令/bin/bash-c"$(curl-fsSLhttps://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"。2.更新Homebrew,使用brewupdate。3.安装MySQL,使用brewinstallmysql。4.启动MySQL服务,使用brewservicesstartmysql。安装后,可通过mysql-u

MySQL函数可用于数据处理和计算。1.基本用法包括字符串处理、日期计算和数学运算。2.高级用法涉及结合多个函数实现复杂操作。3.性能优化需避免在WHERE子句中使用函数,并使用GROUPBY和临时表。

要安全、彻底地卸载MySQL并清理所有残留文件,需遵循以下步骤:1.停止MySQL服务;2.卸载MySQL软件包;3.清理配置文件和数据目录;4.验证卸载是否彻底。

MySQL批量插入数据的高效方法包括:1.使用INSERTINTO...VALUES语法,2.利用LOADDATAINFILE命令,3.使用事务处理,4.调整批量大小,5.禁用索引,6.使用INSERTIGNORE或INSERT...ONDUPLICATEKEYUPDATE,这些方法能显着提升数据库操作效率。

MySQL被广泛应用于各种项目中的原因包括:1.高性能与可扩展性,支持多种存储引擎;2.易于使用和维护,配置简单且工具丰富;3.丰富的生态系统,吸引大量社区和第三方工具支持;4.跨平台支持,适用于多种操作系统。

使用EXPLAIN命令可以分析MySQL查询的执行计划。1.EXPLAIN命令显示查询的执行计划,帮助找出性能瓶颈。2.执行计划包括id、select_type、table、type、possible_keys、key、key_len、ref、rows和Extra等字段。3.根据执行计划,可以通过添加索引、避免全表扫描、优化JOIN操作和使用覆盖索引来优化查询。

在MySQL中配置字符集和排序规则的方法包括:1.设置服务器级别的字符集和排序规则:SETNAMES'utf8';SETCHARACTERSETutf8;SETCOLLATION_CONNECTION='utf8_general_ci';2.创建使用特定字符集和排序规则的数据库:CREATEDATABASEexample_dbCHARACTERSETutf8COLLATEutf8_general_ci;3.创建表时指定字符集和排序规则:CREATETABLEexample_table(idINT
