国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

java 批量插入數(shù)據(jù)

這篇具有很好參考價值的文章主要介紹了java 批量插入數(shù)據(jù)。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

批量插入數(shù)據(jù),常見的使用mybatis foreach 插入的方式,原始的方式和批處理

1,常見的mybatis foreach

xml

<insert id="insertBatch"  parameterType="java.util.List">
		insert into  CODEINFO (CODE_TYPE, CODE, MEAN, STATE, SORT_ID)
		values
		<foreach collection ="records" item="item" separator =",">
			(#{item.codeType}, #{item.code},
			 #{item.remark},  #{item.state}, #{item.sortId})
		</foreach >
	</insert>

mapper:

int insertBatch(@Param("records") List<CodeInfo> records);

對于數(shù)據(jù)量不是很大的,基本夠用。如果同步數(shù)據(jù)特別慢,再考慮其它的方式?;蛘咄砩狭璩吭偻綌?shù)據(jù)。

2,原始的方式

批量插入

public void insertBatach(){
        Connection conn=null;
        PreparedStatement ps=null;
        try {
            long start = System.currentTimeMillis();

            conn = JDBCUtils.getConnection();
            conn.setAutoCommit(false);
            String sql="INSERT INTO CODEINFO (CODE_TYPE, CODE, MEAN,STATE, SORT_ID) VALUES (?, ?, ?, ?, ?)";
            ps = conn.prepareStatement(sql);
            for(int i=1;i<=20000;i++){
                ps.setObject(1, "TEST_INSERT_BATCH");
                ps.setObject(2, "0"+i);
                ps.setObject(3, "name_"+i);
                ps.setObject(4, "0SA");
                ps.setObject(5, i);
                //1.sql
                ps.addBatch();

                if(i%500==0){
                    //2.執(zhí)行batch
                    ps.executeBatch();

                    //3.清空batch
                    ps.clearBatch();
                }
            }

            //提交數(shù)據(jù)
            conn.commit();
            long end = System.currentTimeMillis();
            System.out.println("批量插入花費的時間為:"+(end-start));
        } catch (Exception e) {
            e.printStackTrace();
        } finally{
            JDBCUtils.close(conn, ps);
        }
    }

數(shù)據(jù)庫連接:

import java.io.IOException;
import java.io.InputStream;
import java.sql.*;
import java.util.Properties;

public class JDBCUtils {
    private static String url;
    private static String user;
    private static String password;
    private static  Connection conn = null;
    //    靜態(tài)代碼塊
    static{
        /* 將外部properties文件放在src文件夾中,用類的加載器讀文件,格式:
         * 當(dāng)前類名.class.getClassLoader().getResourceAsStream("外部文件名");*/
        InputStream in = JDBCUtils.class.getClassLoader().getResourceAsStream("sql.properties");
        Properties p=new Properties();
        try {
            p.load(in);
        } catch (IOException e) {
            e.printStackTrace();
        }
//        讀文件給變量賦值
        String driver = p.getProperty("driver");
        url = p.getProperty("url");
        user = p.getProperty("user");
        password = p.getProperty("password");
        try {
            Class.forName(driver);
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }
    }

    //    構(gòu)造獲得數(shù)據(jù)庫鏈接方法
    public static Connection getConnection() {
        try {
            conn = DriverManager.getConnection(url, user, password);
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return conn;
    }
    //    構(gòu)造關(guān)閉流的方法
    public static void close(Connection conn,Statement stat) {
        if (stat != null) {
            try {
                stat.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        if (conn != null) {
            try {
                conn.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }
    //    重載關(guān)閉流的方法
    public static void close(Connection conn,Statement stat, ResultSet rs) {
        if (rs != null) {
            try {
                rs.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        if (stat != null) {
            try {
                stat.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        if (conn != null) {
            try {
                conn.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }
}

原始的方法寫起來麻煩些。

3,批處理

MybatisGeneralBatchUtils?

import org.apache.ibatis.session.ExecutorType;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import org.springframework.transaction.support.TransactionSynchronizationManager;

import java.util.List;
import java.util.function.BiFunction;


@Component
public class MybatisGeneralBatchUtils {
    private static final Logger logger = LoggerFactory.getLogger(MybatisGeneralBatchUtils.class);
    /**
     * 每次處理1000條
     */
    private static final int BATCH_SIZE = 1000;

    /**
     * 批量處理修改或者插入
     *  變成一條一條的數(shù)據(jù),然后最后一起執(zhí)行。并不是 insertBatch那種方式
     * @param data        需要被處理的數(shù)據(jù)
     * @param mapperClass Mybatis的Mapper類
     * @param function    自定義處理邏輯
     * @return int 影響的總行數(shù)
     */
    public <T, U, R> int batchUpdateOrInsert(List<T> data, Class<U> mapperClass, BiFunction<T, U, R> function)  {
        int i = 1;
        SqlSessionFactory sqlSessionFactory = (SqlSessionFactory) SpringUtil.getBean("sqlSessionFactory");
        SqlSession batchSqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH);
        try {
            U mapper = batchSqlSession.getMapper(mapperClass);
            int size = data.size();
            for (T element : data) {
                function.apply(element, mapper);
                if ((i % BATCH_SIZE == 0) || i == size) {
                    batchSqlSession.flushStatements();
                }
                i++;
            }
            // 非事務(wù)環(huán)境下強制commit,事務(wù)情況下該commit相當(dāng)于無效
            batchSqlSession.commit(!TransactionSynchronizationManager.isSynchronizationActive());
        } catch (Exception e) {
            batchSqlSession.rollback();
            logger.error("batchUpdateOrInsert", e);
        } finally {
            batchSqlSession.close();
        }
        return i - 1;
    }

}

SpringUtil?

import org.springframework.beans.BeansException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.stereotype.Component;

@Component
public class SpringUtil implements ApplicationContextAware {

    private static ApplicationContext applicationContext;

    public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
         SpringUtil.applicationContext = applicationContext;
    }

    public static Object getBean(String name) {
        return applicationContext.getBean(name);
    }

    public static <T> T getBean(Class<T> clazz) {
        return applicationContext.getBean(clazz);
    }
}

調(diào)用:

mapper:

int insertSelective(CodeInfo codeInfo);

xml:

<insert id="insertSelective" parameterType="com.web.dict.entity.CodeInfo">
		insert into CODEINFO
		<trim prefix="(" suffix=")" suffixOverrides=",">
			<if test="codeType != null">
				CODE_TYPE,
			</if>
			<if test="code != null">
				CODE,
			</if>
			<if test="mean != null">
				MEAN,
			</if>
			<if test="state != null">
				STATE,
			</if>
			<if test="sortId != null">
				SORT_ID,
			</if>
		</trim>
		<trim prefix="values (" suffix=")" suffixOverrides=",">
			<if test="codeType != null">
				#{codeType,jdbcType=VARCHAR},
			</if>
			<if test="code != null">
				#{code,jdbcType=VARCHAR},
			</if>
			<if test="mean != null">
				#{mean,jdbcType=VARCHAR},
			</if>
			<if test="state != null">
				#{state,jdbcType=VARCHAR},
			</if>
			<if test="sortId != null">
				#{sortId,jdbcType=VARCHAR},
			</if>
		</trim>
	</insert>

service:

    @Resource
    private MybatisGeneralBatchUtils mybatisGeneralBatchUtils;

    public int batchInsertData(List<CodeInfo> codeInfos){
        return mybatisGeneralBatchUtils.batchUpdateOrInsert(codeInfos, CodeInfoMapper.class,
                (item, codeInfoMapper) -> codeInfoMapper.insertSelective(item));
    }

這個方法看起來比較通用,但是我自己測的話,速度反而比較慢。可能是因為模擬的字段和數(shù)據(jù)都比較少;后面有遇到數(shù)據(jù)量大的,再進行一個比對。

官網(wǎng)推薦的方法:

MyBatis文檔中寫批量插入的時候,是推薦使用另外一種方法?中?Batch Insert Support?標題里的內(nèi)容

try(SqlSession session = sqlSessionFactory.openSession(ExecutorType.BATCH)) {
        SimpleTableMapper mapper = session.getMapper(SimpleTableMapper.class);
        List<SimpleTableRecord> records = getRecordsToInsert(); // not shown

        BatchInsert<SimpleTableRecord> batchInsert = insert(records)
                .into(simpleTable)
                .map(id).toProperty("id")
                .map(firstName).toProperty("firstName")
                .map(lastName).toProperty("lastName")
                .map(birthDate).toProperty("birthDate")
                .map(employed).toProperty("employed")
                .map(occupation).toProperty("occupation")
                .build()
                .render(RenderingStrategies.MYBATIS3);

        batchInsert.insertStatements().forEach(mapper::insert);

        session.commit();
    }

總結(jié):

? ? ?如果數(shù)據(jù)量不大,能第一種就夠了。如果數(shù)據(jù)內(nèi)容多,字段又多,試試其它的方式,看下效率是否有更快。 同步數(shù)據(jù),還是適合晚上的時候,用定時器去跑。文章來源地址http://www.zghlxwxcb.cn/news/detail-515818.html

到了這里,關(guān)于java 批量插入數(shù)據(jù)的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • SpringBoot+MyBatis批量插入數(shù)據(jù)的三種方式

    最近導(dǎo)入表格數(shù)據(jù)時需要同時插入修改大量數(shù)據(jù),研究了一下有三種實現(xiàn)方式 1、用for循環(huán)調(diào)用sql插入數(shù)據(jù) 這種方式插入大量數(shù)據(jù)時,效率非常底下,不推薦 2、利用mybatis的foreach來實現(xiàn)循環(huán)插入 這種方式插入大量數(shù)據(jù)時,好處是不用頻繁訪問數(shù)據(jù)庫,一條sql搞定,效率比較

    2024年02月16日
    瀏覽(20)
  • mybatis批量插入數(shù)據(jù)導(dǎo)致系統(tǒng)OOM,微服務(wù)內(nèi)存爆了

    mybatis批量插入數(shù)據(jù)導(dǎo)致系統(tǒng)OOM,微服務(wù)內(nèi)存爆了

    今天我們來說說工作中遇到的一個真實案例,由于使用mybatis的批量插入功能,導(dǎo)致系統(tǒng)內(nèi)存溢出OOM(Out Of Memory), \\\"java.lang.OutOfMemoryError: Java heap space\\\"的報錯,導(dǎo)致服務(wù)出現(xiàn)短暫的服務(wù)不可用,大概一兩分鐘不可用。這其實是個非常危險的故障,可能在高峰期導(dǎo)致整個系統(tǒng)癱

    2024年02月01日
    瀏覽(22)
  • Mysql大數(shù)據(jù)批量插入方法

    MySQL是當(dāng)前最流行的關(guān)系型數(shù)據(jù)庫之一,大數(shù)據(jù)批量插入是MySQL中常用的操作之一。在處理大量數(shù)據(jù)時,如果一條一條地插入會極大地影響效率,因此批量插入是一個更好的選擇,可以大大提高數(shù)據(jù)的處理速度。下面介紹幾種MySQL大數(shù)據(jù)批量插入的方法。 使用LOAD DATA INFILE語句

    2024年02月10日
    瀏覽(19)
  • python批量插入數(shù)據(jù)到mysql

    使用python批量插入數(shù)據(jù)到mysql的三種方法 單條insert的話插入5w條數(shù)據(jù)大約用時5秒左右,相對來說效率不高

    2024年02月10日
    瀏覽(19)
  • MySQL---使用索引優(yōu)化、大批量插入數(shù)據(jù)優(yōu)化

    MySQL---使用索引優(yōu)化、大批量插入數(shù)據(jù)優(yōu)化

    1. 使用索引優(yōu)化 索引是數(shù)據(jù)庫優(yōu)化最常用也是最重要的手段之一 , 通過索引通??梢詭椭脩艚鉀Q大多數(shù)的 MySQL 的性能優(yōu)化問題: 1.1?避免索引失效應(yīng)用-全值匹配 該情況下,索引生效,執(zhí)行效率高。 1.2?避免索引失效應(yīng)用-最左前綴法則 1.3?避免索引失效應(yīng)用-其他匹配原則

    2024年02月07日
    瀏覽(24)
  • java實現(xiàn)批量插入數(shù)據(jù)

    日常工作或者學(xué)習(xí)中,可能會遇到批量插入數(shù)據(jù)的需求,一般情況下數(shù)據(jù)量少的時候,我們會直接調(diào)用批量接口插入數(shù)據(jù)即可,當(dāng)數(shù)據(jù)量特別大時,可能由于數(shù)據(jù)庫限制,插入的數(shù)據(jù)最多不能超過100條(假如限制100條),就算是數(shù)據(jù)庫支持一次性插入千條也會耗內(nèi)存,如果使用

    2024年02月11日
    瀏覽(21)
  • java 批量插入數(shù)據(jù)

    批量插入數(shù)據(jù),常見的使用mybatis foreach 插入的方式,原始的方式和批處理 xml mapper: 對于數(shù)據(jù)量不是很大的,基本夠用。如果同步數(shù)據(jù)特別慢,再考慮其它的方式。或者晚上凌晨再同步數(shù)據(jù)。 批量插入 數(shù)據(jù)庫連接: 原始的方法寫起來麻煩些。 MybatisGeneralBatchUtils? SpringUtil?

    2024年02月11日
    瀏覽(17)
  • Mysql 實現(xiàn)批量插入對已存在數(shù)據(jù)忽略或更新

    Mysql 實現(xiàn)批量插入對已存在數(shù)據(jù)忽略或更新

    對已存在的數(shù)據(jù)進行 忽略/更新 ,需要唯一索引/主鍵。 唯一索引可為多個字段的聯(lián)合索引,比如根據(jù)我提供的sql中,我需要``name + age`不重復(fù),則可把這2個字段聯(lián)合創(chuàng)建為唯一索引 創(chuàng)建聯(lián)合唯一索引的sql 批量插入對已存在數(shù)據(jù)忽略 批量插入對已存在數(shù)據(jù)更新 筆者這里只舉

    2024年02月15日
    瀏覽(29)
  • Mybatis批量插入

    使用Mybatis框架批量插入的3種方法:多次調(diào)用insert方法、foreach標簽、batch模式 后端java代碼:

    2024年02月12日
    瀏覽(18)
  • Mybatis批量插入、修改

    ? ? ? ? 在 MyBatis 中, foreach 標簽用于遍歷集合類型的條件,并且可以將多個參數(shù)值拼接成為 SQL 語句的一個部分,通常被用于批量插入或更新等操作。? foreach屬性及介紹 ? ? ? ?? 屬性 介紹 collection 集合名稱 item 字符別名 index 索引別名 open 循環(huán)前綴 close 循環(huán)后綴 separato

    2024年02月07日
    瀏覽(19)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包