JdbcTemplate using Spring Boot provides update(String sql, Object... args) method which supports upsert (nsert or update if exists) operation. You can use this method to perform an upsert operation in the database.
Code Snippet:String sql = "INSERT INTO employee (employeeId, employeeName, employeeDateOfBirth, employeeDepartment, employeeJoiningDate, employeeSalary) " +
"VALUES (:id, :name, :dob, :department, :joiningDate, :salary) " +
"ON DUPLICATE KEY UPDATE " +
"employeeName=VALUES(employeeName), " +
"employeeDateOfBirth=VALUES(employeeDateOfBirth), " +
"employeeDepartment=VALUES(employeeDepartment), " +
"employeeJoiningDate=VALUES(employeeJoiningDate), " +
"employeeSalary=VALUES(employeeSalary)";
MapSqlParameterSource[] batchParams = employees.stream()
.map(employee -> new MapSqlParameterSource()
.addValue("id", employee.getEmployeeId())
.addValue("name", employee.getEmployeeName())
.addValue("dob", Date.valueOf(employee.getEmployeeDateOfBirth()))
.addValue("department", employee.getEmployeeDepartment())
.addValue("joiningDate", Date.valueOf(employee.getEmployeeJoiningDate()))
.addValue("salary", employee.getEmployeeSalary()))
.toArray(MapSqlParameterSource[]::new);
namedParameterJdbcTemplate.batchUpdate(sql, batchParams);
Related Examples:
- Spring Boot: NamedParameterJdbcTemplate batch insert example
- JdbcTemplate Batch Insert Example using Spring Boot
- Spring Boot: JDBCTemplate BatchUpdate Update Query Example
- Spring Boot: JdbcTemplate Update Query With Parameters Example
- JDBCTemplate Querying Examples with Spring Boot 3
Facing issues? Have Questions? Post them here! I am happy to answer!
Author Info:
Rakesh (He/Him) has over 14+ years of experience in Web and Application development. He is the author of insightful How-To articles for Code2care.
Follow him on: X
You can also reach out to him via e-mail: rakesh@code2care.org
More Posts related to Java,
- Get the current timestamp in Java
- Java Stream with Multiple Filters Example
- Java SE JDBC with Prepared Statement Parameterized Select Example
- Fix: UnsupportedClassVersionError: Unsupported major.minor version 63.0
- [Fix] Java Exception with Lambda - Cannot invoke because object is null
- 7 deadly java.lang.OutOfMemoryError in Java Programming
- How to Calculate the SHA Hash Value of a File in Java
- Java JDBC Connection with Database using SSL (https) URL
- How to Add/Subtract Days to the Current Date in Java
- Create Nested Directories using Java Code
- Spring Boot: JDBCTemplate BatchUpdate Update Query Example
- What is CA FE BA BE 00 00 00 3D in Java Class Bytecode
- Save Java Object as JSON file using Jackson Library
- Adding Custom ASCII Text Banner in Spring Boot Application
- [Fix] Java: Type argument cannot be of primitive type generics
- List of New Features in Java 11 (JEPs)
- Java: How to Add two Maps with example
- Java JDBC Transition Management using PreparedStatement Examples
- Understanding and Handling NullPointerException in Java: Tips and Tricks for Effective Debugging
- Steps of working with Stored Procedures using JDBCTemplate Spring Boot
- Java 8 java.util.Function and BiFunction Examples
- The Motivation Behind Generics in Java Programming
- Get Current Local Date and Time using Java 8 DateTime API
- Java: Convert Char to ASCII
- Deep Dive: Why avoid java.util.Date and Calendar Classes
More Posts:
- How to download Microsoft Visual Studio for M1/M2 Mac - MacOS
- AWS S3 CLI BucketAlreadyExists when calling CreateBucket Error make_bucket failed - AWS
- [Solution] Exception in thread main java.util.EmptyStackException - Java
- [Fix] ValueError: substring not found in Python - Python
- How to show End of Line Characters in File using Notepad++ - NotepadPlusPlus
- How to the Install Official Android Emulator for Mac? - Android
- Calculate discount amount python code - Python
- Adding Widgets to Mac Desktop Screen on macOS Sonoma 14 - MacOS