🎓 Top 15 Udemy Courses (80-90% Discount): My Udemy Courses - Ramesh Fadatare — All my Udemy courses are real-time and project oriented courses.
▶️ Subscribe to My YouTube Channel (178K+ subscribers): Java Guides on YouTube
▶️ For AI, ChatGPT, Web, Tech, and Generative AI, subscribe to another channel: Ramesh Fadatare on YouTube
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=updateMake 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.
My Top and Bestseller Udemy Courses. The sale is going on with a 70 - 80% discount. The discount coupon has been added to each course below:
Build REST APIs with Spring Boot 4, Spring Security 7, and JWT
[NEW] Learn Apache Maven with IntelliJ IDEA and Java 25
ChatGPT + Generative AI + Prompt Engineering for Beginners
Spring 7 and Spring Boot 4 for Beginners (Includes 8 Projects)
Available in Udemy for Business
Building Real-Time REST APIs with Spring Boot - Blog App
Available in Udemy for Business
Building Microservices with Spring Boot and Spring Cloud
Available in Udemy for Business
Java Full-Stack Developer Course with Spring Boot and React JS
Available in Udemy for Business
Build 5 Spring Boot Projects with Java: Line-by-Line Coding
Testing Spring Boot Application with JUnit and Mockito
Available in Udemy for Business
Spring Boot Thymeleaf Real-Time Web Application - Blog App
Available in Udemy for Business
Master Spring Data JPA with Hibernate
Available in Udemy for Business
Spring Boot + Apache Kafka Course - The Practical Guide
Available in Udemy for Business
Comments
Post a Comment
Leave Comment