这是CodingSir的帖子说的(由于不够详细,我现在提供给详细的,上手即用):

Microsoft SQL Server 的bcp命令可以快速将大型文件复制插入到数据库中,C#提供了SqlBulkCopy方法实现该功能,而在java中可以通过SQLServerBulkCopy类实现类似的功能,且相对于insert、update等命令来说,这个类的效率要高的多。(对比常用的JDBC的Batch方法也高的多)。

SQLServerBulkCopy类只能用于对SQL Sever数据库的插入,但是数据来源可以不是SQL Sever数据库。

旧版的Microsoft SQL Server JDBC 驱动并没有提供这个类,需要下载Microsoft SQL Server JDBC 驱动程序 6.0版本:https://www.microsoft.com/zh-cn/download/confirmation.aspx?id=11774

MS官方的说明文档和下载架包在这个地址:https://docs.microsoft.com/en-us/sql/connect/jdbc/using-bulk-copy-with-the-jdbc-driver

SQLServerBulKCopy类向数据库插入数据支持三种类型封装的数据:Java本身提供的ResultSet、RowSet和JDBC提供的ISQLServerBulkRecord接口实现类。下面提供一种实现:

BaseDao代码:
public class BaseDao {
//驱动
private static String driver = "com.microsoft.sqlserver.jdbc.SQLServerDriver"; //数据库地址
private static String url = "jdbc:sqlserver://127.0.0.1:1433;SelectMethod=cursor;DatabaseName=数据库名字;"; //数据库用户名
private static String name = "sa"; //数据库密码
private static String password = "123456"; //数据库连接,定义为全局变量,方便调用
private Connection con; //导入驱动,静态代码块的作用为只运行一次,异常无法向上抛出,只能及时处理
static{
try{
Class.forName(driver);
}catch (ClassNotFoundException e) {
//打印异常相关信息
e.printStackTrace();
}
} //无参构造方法,连接数据库
public BaseDao () {
try {
con=DriverManager.getConnection(url,name,password);
} catch (SQLException throwables) {
throwables.printStackTrace();
}
} //数据查找,返回查找的内容,向上抛异常
public ResultSet executeSQL (String sql,Object...object) throws SQLException{
PreparedStatement ps=con.prepareStatement(sql); for(int i=0;i<object.length;i++){
//ps传入参数的下标是从1开始
ps.setObject(i+1,object[i]);
} //返回结果集
return ps.executeQuery();
} //数据的增删改,返回数据执行行数
public int executeUpdate(String sql,Object...object) throws SQLException {
PreparedStatement ps=con.prepareStatement(sql);
for(int i=0;i<object.length;i++){
ps.setObject(i+1,object[i]);
}
//返回int类型执行行数
return ps.executeUpdate();
} //关闭数据库连接
public void close() throws SQLException{
con.close();
}
}

下面的代码,大家可以也封装成工具类:

public static void main(String[] args) {
    String url = "jdbc:sqlserver://127.0.0.1:1433;SelectMethod=cursor;DatabaseName=ry"
+ ";user=sa;password=123456";
//查询出空值用于构建CachedRowSetImpl对象以省去列映射的步骤
BaseDao baseDao=new BaseDao();
ResultSet rs = baseDao.executeSQL("select * from curr where 1=0");
CachedRowSetImpl crs = new CachedRowSetImpl();
crs.populate(rs);

     //既然是批量插入肯定是需要循环
     for(int i=0;i<执行的次数;i++){
  //移动指针到“插入行”,插入行是一个虚拟行
  crs.moveToInsertRow();
  //更新虚拟行的数据(实体类要新增的字段,大家根据自己的实体类的字段来修改)
                 //数据库字段 ,填写的值
  crs.updateString("monetary_code", "014");//string类型的值
  crs.updateString("curr_code", "CNY");
  crs.updateString("name", "人民币");
       //别的类型的值,自己看api,基本上都是crs.update***这样的
  //crs.updateInt("curr_code", 2);//int类型的值
  //插入虚拟行
  crs.insertRow();
  //移动指针到当前行
  crs.moveToCurrentRow();
     }

     //进行批量插入
SQLServerBulkCopyOptions copyOptions = new SQLServerBulkCopyOptions();
copyOptions.setKeepIdentity(true);
copyOptions.setBatchSize(8000);
copyOptions.setUseInternalTransaction(true);
SQLServerBulkCopy bulkCopy = new SQLServerBulkCopy(url);
bulkCopy.setBulkCopyOptions(copyOptions);
bulkCopy.setDestinationTableName("curr");
bulkCopy.writeToServer(crs);
crs.close();
bulkCopy.close();
}

感想:由于大牛对小白关照细节不到位,所以决定写篇详细的给你们,节省大家的时间。

Java使用SQLServerBulKCopy实现批量插入SQLSqerver数据库的更多相关文章

  1. C# 数据批量插入到数据库SqlBulkCopy(源数据类型:List<T> Or DataTable)

      /*_____________________ List<T>类型数据 To Sql_______________________________*/ /// <summary& ...

  2. [Java]如何把当前时间插入到数据库

    [Java]如何把当前时间插入到数据库 1.在orderDao.java中 /** 设置订单*/ public void setOrder(Order order){ Date time = new ...

  3. java中解析excel 批量插入数据库

    Facade 层 实现类 (@Service("samePeriodModelImportFacade")) 1.  获取cells 的方法 public Cells getCel ...

  4. Mybatis与JDBC批量插入MySQL数据库性能测试及解决方案

    转自http://www.cnblogs.com/fnz0/p/5713102.html 不知道自己什么时候才有这种钻研精神- -. 1      背景 系统中需要批量生成单据数据到数据库表,所以采用 ...

  5. python批量插入mysql数据库(性能相关)以及反引号的使用

    参考link: https://blog.csdn.net/qq_35958094/article/details/78462800(插入相关) https://www.cnblogs.com/hya ...

  6. C# OracleBulkCopy 批量插入oracle数据库的方法

    只有安装了oracle 11G客户端的机器上才可以用,要用到ODP.NET组件中的oracleDataAccess.DLL,命名空间引用为Oracle.DataAccess.Client; 引用:Or ...

  7. C#动态创建Gridview及批量插入到数据库

    这里介绍两种动态创建Gridview的方法: (一).有时需要应付上头领导的检查,所以就弄一些静态的Gridview来显示数据,这种方法的优点就是不用连接数据库,比较方便,但是代码灵活性不高,所有数据 ...

  8. C#批量插入Sybase数据库,Anywhere 8

    数据库版本是Adaptive Server Anywhere 8 1.添加引用,程序集 iAnywhere.Data.AsaClient.这个和SQLServer的System.Data.SqlCli ...

  9. Django—ajax、前端后端编码格式,bulk_create批量插入语数据库、自定义分页

    一.ajax简介: XML也是一门标记语言该语法应用场景 1.写配置文件 2.可以写前端页面(odoo框架中 erp) 每家公司都会有属于这家公司独有的内部管理软件:专门用来开发企业内部管理软件 框架 ...

随机推荐

  1. 赛艇表演 51nod提高组模拟试题

    AC通道 题目描述 小明去某个地区观看赛艇比赛,这个地区共有n个城市和m条道路,每个城市都有赛艇比赛,在第i个 城市观看赛艇表演的价钱为ai, 去其他城市观看也需要支付赛艇表演的价格.任意两个城市之间 ...

  2. 【转】动态规划:最长递增子序列Longest Increasing Subsequence

    转自:https://www.cnblogs.com/coffy/p/5878915.html 设f(i)表示L中以ai为末元素的最长递增子序列的长度.则有如下的递推方程: 这个递推方程的意思是,在求 ...

  3. Springboot 内置tomcat 基本配置收集整理

    配置一: server:# tomcat 配置  tomcat:    # 接收队列长度    accept-count: 1000    # 最小空闲线程数    min-spare-threads ...

  4. python基本操作-文件、目录及路径

    目录 1 前言 2 文件夹操作 2.1 查询操作 2.2 创建操作 2.3 删除操作 2.4 修改操作 3 文件操作 3.1 查询操作 3.2 创建操作 3.3 修改操作 3.4 删除 4 路径操作 ...

  5. 实用教程丨使用K3s和MySQL运行Rancher 2.4

    本文转自Rancher Labs 简 介 本文将介绍在高可用K3s Kubernetes集群上安装Rancher 2.4的过程并针对MySQL利用Microsoft Azure数据库的优势,该数据库消 ...

  6. jQuery-操作元素的内容,属性,样式

    1.操作内容 获取: 双标签:html() input:val() 设置: 双标签:html('新内容') input:val('新内容') 2.操作属性 * 获取:attr('属性名') * 设置: ...

  7. jchdl - GSL实例 - DFlipFlop(D触发器)

    https://mp.weixin.qq.com/s/7N3avTxTd2ZUnAcKg4w3Ig   D触发器对边沿敏感,只有当相应的边沿出现时,才会触发D的值传播到输出Q.   ​​ 引自:htt ...

  8. 可以Postman,也可以cURL.进来领略下cURL的独门绝技

    文章已经收录在 Github.com/niumoo/JavaNotes ,更有 Java 程序员所需要掌握的核心知识,欢迎Star和指教. 欢迎关注我的公众号,文章每周更新. cURL 是一个开源免费 ...

  9. Java 第十一届 蓝桥杯 省模拟赛 最大的元素距离

    在数列 a_1, a_2, -, a_n中,定义两个元素 a_i 和 a_j 的距离为 |i-j|+|a_i-a_j|,即元素下标的距离加上元素值的差的绝对值,其中 |x| 表示 x 的绝对值. 给定 ...

  10. Java实现 蓝桥杯 算法训练 找零钱

    试题 算法训练 找零钱 问题描述 有n个人正在饭堂排队买海北鸡饭.每份海北鸡饭要25元.奇怪的是,每个人手里只有一张钞票(每张钞票的面值为25.50.100元),而且饭堂阿姨一开始没有任何零钱.请问饭 ...