In this tutorial, you will learn how to use Spring Data JPA to perform batch insert operation in Spring Boot Application.
1. Set up a Spring Boot project
Let's launch Spring Initializr and fill up the following project details:
Project: Maven Project (or Gradle)
Language: Java
Packaging: Jar
Java version: 17
Dependencies: Spring Data JPA, MySQL Driver, and Lombok
Download, extract the project, and import it to your favorite IDE.
2. Configure the MySQL database
Let's open the src/main/resources/application.properties file and add the MySQL configuration properties:
spring.datasource.url=jdbc:mysql://localhost:3306/demo
spring.datasource.username=root
spring.datasource.password=Mysql@123
spring.jpa.hibernate.ddl-auto=update
Make sure that you change the MySQL database username and password as per your MySQL installation on your machine.
The spring.jpa.hibernate.ddl-auto=update line ensures that tables and columns get automatically created or updated based on your JPA entities.
3. Create Entity
For the sake of this example, let's use a Person entity:
import jakarta.persistence.*;
import lombok.Getter;
import lombok.Setter;
@Setter
@Getter
@Entity
@Table(name = "persons")
public class Person {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
private String name;
private String email;
}
4. Create Spring Data JPA Repository - PersonRepository
Let's create an PersonRepository interface that extends the JpaRepository interface from Spring Data JPA:
import com.springdatajpa.springboot.entity.Person;
import org.springframework.data.jpa.repository.JpaRepository;
public interface PersonRepository extends JpaRepository<Person, Long> {
}
5. Service Layer
To perform the batch insert, use the saveAll method provided by Spring Data JPA:
@Service
public class PersonService {
@Autowired
private PersonRepository personRepository;
@Transactional
public List<Person> savePersons(List<Person> persons) {
return personRepository.saveAll(persons);
}
}
Remember to mark the method with @Transactional to ensure it runs within a transaction.
6. Testing the Batch Insert
You can test the batch insert operation by creating a list of Person objects and saving them using the service:
@SpringBootTest
public class BatchInsertTest {
@Autowired
private PersonService personService;
@Test
public void testBatchInsert() {
List<Person> persons = new ArrayList<>();
for (int i = 0; i < 200; i++) {
persons.add(new Person("Name" + i, "name" + i + "@example.com"));
}
personService.savePersons(persons);
// Add assertions or further test logic as needed.
}
}
Conclusion
Batch inserts can dramatically improve performance when inserting a large number of entities. By setting up the correct configurations and using the tools provided by Spring Data JPA, you can easily integrate batch operations into your Spring Boot application.
Comments
Post a Comment
Leave Comment