> 데이터 베이스 > MySQL 튜토리얼 > Java의 ReadyStatement를 사용하여 MySQL에서 여러 행 삽입을 최적화하는 방법은 무엇입니까?

Java의 ReadyStatement를 사용하여 MySQL에서 여러 행 삽입을 최적화하는 방법은 무엇입니까?

Barbara Streisand
풀어 주다: 2024-12-27 09:11:10
원래의
611명이 탐색했습니다.

How to Optimize Multiple Row Inserts in MySQL using Java's PreparedStatement?

Java에서 ReadyStatement를 사용하여 동시에 여러 행 삽입

질문:

최적화 방법 지원되는 MySQL 구문을 활용하여 Java를 사용하여 MySQL 테이블에 여러 행을 삽입합니다. 하나의 명령문에 여러 값을 삽입합니까?

답변:

PreparedStatement#addBatch() 및 preparedStatement#executeBatch()를 활용하면 일괄 삽입 및 해당 항목을 생성할 수 있습니다. 후속 실행.

예:

일괄 삽입을 시작하려면 다음 예를 고려하십시오.

public void save(List<Entity> entities) throws SQLException {
    try (
        Connection connection = database.getConnection();
        PreparedStatement statement = connection.prepareStatement(SQL_INSERT);
    ) {
        int i = 0;

        for (Entity entity : entities) {
            statement.setString(1, entity.getSomeProperty());
            // ...

            statement.addBatch();
            i++;

            if (i % 1000 == 0 || i == entities.size()) {
                statement.executeBatch(); // Execute every 1000 items.
            }
        }
    }
}
로그인 후 복사

구현 세부 정보:

  • 삽입은 일괄적으로 수행됩니다. 배치 길이에 대한 JDBC 드라이버 또는 데이터베이스의 잠재적인 제한을 피하기 위해 1000개입니다.
  • JDBC 튜토리얼에서는 ReadyStatements 및 배치 업데이트 사용에 대한 추가 리소스를 제공합니다.

위 내용은 Java의 ReadyStatement를 사용하여 MySQL에서 여러 행 삽입을 최적화하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿