자바 반사 메커니즘 을 이용 하여 동적 생 성 Sql 실현
데이터 이전 을 위 한 작은 도 구 를 만 들 려 면 대량의 정 리 된 대상 데 이 터 를 다른 표 에 삽입 해 야 합 니 다. 기 존의 방식 에 따라 작업량 이 많 기 때문에 반사 메커니즘 동적 + my baits 를 이용 하여 동적 으로 Sql 을 생 성하 고 대량으로 입고 하 는 것 을 고려 합 니 다.
코드
mybatis 주해 @ InsertProvider 지정 방법 으로 SQL 문장 생 성
package com.company.cutover.provider.mapper.jydp;
import org.apache.ibatis.annotations.InsertProvider;
import org.apache.ibatis.annotations.Param;
import java.util.List;
/**
* @author ryzhang5
* @Package com.company.cutover.provider.mapper.jydp
* @date 2020/7/19 17:30
* @Copyright
*/
public interface InsertDataMapper {
@InsertProvider(type = DynamicSqlProvider.class, method = "genCreateTableSql")
Integer insertData(@Param("list") List> list, @Param("bean") Class bean);
}
package com.company.cutover.provider.mapper.jydp;
import org.springframework.util.ReflectionUtils;
import java.beans.PropertyDescriptor;
import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.util.List;
import java.util.Map;
/**
* @author ryzhang5
* @Package com.company.cutover.provider.mapper.jydp
* @date 2020/7/19 16:41
* @Copyright
*/
public class DynamicSqlProvider {
/**
* sql
* @param data
* @return
*/
public static String genCreateTableSql(Map data){
Class bean = (Class) data.get("bean");
List
주의 하 다.
들 어 오 는 클래스 이름, 필드 이름 은 일치 함 을 표시 해 야 합 니 다.
보충:
대량의 데이터 삽입 문 제 를 고려 하여 데이터 분할 삽입 이 가능 합 니 다.
public void insertData(List> list, Class bean){
// ,
int pageSize = 1000;
int pageIndex = 0;
while(pageIndex * pageSize < list.size()){
int startIndex = pageIndex * pageSize;
int endIndex = (pageIndex + 1) * pageSize;
endIndex = endIndex > list.size() ? list.size() : endIndex;
List> subList = list.subList(startIndex, endIndex);
insertDataMapper.insertData(subList, bean);
try {
Thread.sleep(1);
}catch (Exception e){
e.printStackTrace();
}
pageIndex++;
}
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
JPA + QueryDSL 계층형 댓글, 대댓글 구현(2)이번엔 전편에 이어서 계층형 댓글, 대댓글을 다시 리팩토링해볼 예정이다. 이전 게시글에서는 계층형 댓글, 대댓글을 구현은 되었지만 N+1 문제가 있었다. 이번에는 그 N+1 문제를 해결해 볼 것이다. 위의 로직은 이...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.