The batchUpdate() is a method provided by the JdbcTemplate class in Spring Boot that allows multiple SQL queries to be executed in a batch. It takes an SQL query string and a BatchPreparedStatementSetter object that specifies how to set the parameters for each query.
The batchUpdate() method then executes the SQL query for each set of parameters in a single round-trip to the database, improving performance by reducing the number of database calls.
This method is helpful when multiple queries need to be executed in a single transaction, or when a large number of queries need to be executed with minimal overhead.
import org.springframework.boot.CommandLineRunner;
import org.springframework.jdbc.core.BatchPreparedStatementSetter;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Component;
import org.springframework.stereotype.Repository;
import java.sql.PreparedStatement;
import java.sql.SQLException;
@Repository
public class JDBCTemplateRepo implements CommandLineRunner {
private final JdbcTemplate jdbcTemplate;
public JDBCTemplateRepo(JdbcTemplate jdbcTemplate) {
this.jdbcTemplate = jdbcTemplate;
}
public void batchUpdateRecords(int[] employeeIds, int[] newSalaries) {
String sql = "UPDATE employee SET employeeSalary = ? WHERE employeeId = ?";
jdbcTemplate.batchUpdate(sql, new BatchPreparedStatementSetter() {
@Override
public void setValues(PreparedStatement ps, int i) throws SQLException {
ps.setInt(1, newSalaries[i]);
ps.setInt(2, employeeIds[i]);
}
@Override
public int getBatchSize() {
return employeeIds.length/2; //set per your batch
}
});
}
@Override
public void run(String... args) throws Exception {
int empIdArr[] = {101,201,301,404,505,606,707};
int empSalaryArr[] = {1000,2000,3000,4000,5000,6000,7000};
batchUpdateRecords(empIdArr,empSalaryArr);
}
}

Have Questions? Post them here!
- Create a Zip file using Java Code programmatically
- Eclipse : A java Runtime Environment (JRE) or Java Development kit (JDK) must be available
- How to Sort a LinkedList in Java
- Loading class com.mysql.jdbc.Driver. This is deprecated. The new driver class is com.mysql.cj.jdbc.Driver
- How to declare and initialize Array in Java Programming
- [Fix] java: integer number too large compilation error
- Java JDBC Connection with MySQL Driver in VS Code + Troubleshooting
- Reading .xls and .xlsx Excel file using Apache POI Java Library
- IntelliJ: Error: Could not find or load main class, java.lang.ClassNotFoundException
- How to get Client IP address using Java Code Example
- Truncate table using Java JDBC Example
- Struts 2 : There is no Action mapped for namespace [/] and action name [form] associated with context path [/proj]
- How to get file path in Idea IntelliJ IDE
- Java Generics explained with simple definition and examples
- Java SE 8 Update 301 available with various bug fixes and security improvements
- Java: Collect Stream as ArrayList or LinkedList
- Java JDBC Connection with PostgreSQL Driver Example
- How to check if Java main thread is alive
- How to fix Java nio NoSuchFileException wile reading a file
- Java 8+ get Day of the Week Examples with LocalDateTime, DateTime, ZonalDateTime and Instant classes
- Ways to Convert Integer or int to Long in Java
- [Java] How to throws Exception using Functional Interface and Lambda code
- [Fix] Spring Boot: mysql.cj.jdbc.exceptions.CommunicationsException: Communications link failure
- Java: The value of the local variable string is not used
- Java JDBC: Insert Java 8 LocalDate and Time using PreparedStatement
- cURL Example using IP (IPv4 and IPv6) address and Port - cURL
- Create Safari Shortcut on Mac Desktop - MacOS
- Java monitoring and management console [jconsole] - Java
- How to tar.gz a directory or folder Command - Linux
- Calculate Volume of Pyramid - C-Program
- SharePoint Designer 2010 - errors were found when compiling the workflow - SharePoint
- [fix] zsh: command not found: telnet on Mac - MacOS
- 30+ Zoom video communications application shortcuts for macOS - MacOS