집 >데이터 베이스 >MySQL 튜토리얼 >단일 JDBC 문에서 여러 쿼리를 어떻게 실행할 수 있습니까?
단일 문으로 여러 JDBC 쿼리를 효율적으로 실행
JDBC는 단일 문 내에서 여러 SQL 쿼리를 실행하여 데이터베이스 상호 작용 효율성을 향상시키는 여러 가지 방법을 제공합니다. 한 가지 접근 방식은 allowMultiQueries
연결 속성을 활용하는 것입니다. 이 설정을 사용하면 단일 호출에서 세미콜론으로 구분된 여러 쿼리를 실행할 수 있습니다.
이 기능을 활성화하려면 데이터베이스 URL에 allowMultiQueries=true
을 포함하세요:
<code class="language-java">String dbUrl = "jdbc:mysql:///test?allowMultiQueries=true";</code>
이 기능을 활성화하면 execute()
메소드가 여러 쿼리를 처리할 수 있습니다. 예를 들면 다음과 같습니다.
<code class="language-java">String multiQuerySqlString = "SELECT * FROM table1; INSERT INTO table2 VALUES (1, 'value1');"; boolean hasMoreResultSets = stmt.execute(multiQuerySqlString);</code>
hasMoreResultSets
부울은 추가 결과 세트가 있음을 나타냅니다. 필요에 따라 결과를 반복합니다.
<code class="language-java">while (hasMoreResultSets || stmt.getUpdateCount() != -1) { if (hasMoreResultSets) { ResultSet rs = stmt.getResultSet(); // Process ResultSet data here } else { int queryResult = stmt.getUpdateCount(); // Handle Data Manipulation Language (DML) statement results } hasMoreResultSets = stmt.getMoreResults(); }</code>
또 다른 효과적인 기술은 여러 쿼리를 포함하는 저장 프로시저를 만드는 것입니다. 그런 다음 CallableStatement
을 사용하여 이 절차를 호출할 수 있습니다. 결과는 여러 ResultSet
개체
<code class="language-java">String storedProcedure = "CALL multi_query()"; CallableStatement cstmt = con.prepareCall(storedProcedure); boolean hasMoreResultSets = cstmt.execute(); while (hasMoreResultSets) { ResultSet rs = cstmt.getResultSet(); // Process ResultSet data here hasMoreResultSets = cstmt.getMoreResults(); }</code>
allowMultiQueries
속성과 저장 프로시저 모두 단일 JDBC 문을 사용하여 여러 쿼리를 실행하는 효율적인 방법을 제공하여 데이터베이스 작업을 최적화합니다.
위 내용은 단일 JDBC 문에서 여러 쿼리를 어떻게 실행할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!