Insert record in database with JdbcTemplate (original) (raw)

This is an example of how to insert a record to the database using the JdbcTemplate class provided by the Spring Framework. The JdbcTemplate class is the central class in the JDBC core package. It simplifies the use of JDBC and helps to avoid common errors. It executes core JDBC workflow, leaving application code to provide SQL and extract results. This class executes SQL queries or updates, initiating iteration over ResultSets and catching JDBC exceptions. Inserting a record to the database with JdbcTemplate class implies that you should:

Let’s take a look at the code snippet that follows:

package com.javacodegeeks.snippets.enterprise;

import java.sql.Types; import java.util.Date;

import javax.sql.DataSource;

import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.jdbc.datasource.DriverManagerDataSource;

public class InsertRecordInDatabaseWithJdbcTemplate {

private static final String driverClassName = "com.mysql.jdbc.Driver";
private static final String url = "jdbc:mysql://localhost/companydb";
private static final String dbUsername = "jcg";
private static final String dbPassword = "jcg";

private static final String insertSql =

"INSERT INTO employee (" +

" name, " +

" surname, " +

" title, " +

" created) " +

"VALUES (?, ?, ?, ?)";

private static DataSource dataSource;

public static void main(String[] args) throws Exception {

    dataSource = getDataSource();
    
    saveRecord("John", "Black", "Software developer", new Date());
    saveRecord("Tom", "Green", "Project Manager", new Date());
    
}

public static void saveRecord(String name, String surname, String title, Date created) {
    
    JdbcTemplate template = new JdbcTemplate(dataSource);
    
    // define query arguments
    Object[] params = new Object[] { name, surname, title, new Date() };
    
    // define SQL types of the arguments
    int[] types = new int[] { Types.VARCHAR, Types.VARCHAR, Types.VARCHAR, Types.TIMESTAMP };

    // execute insert query to insert the data
    // return number of row / rows processed by the executed query
    int row = template.update(insertSql, params, types);
    System.out.println(row + " row inserted.");
    
}

public static DriverManagerDataSource getDataSource() {

DriverManagerDataSource dataSource = new DriverManagerDataSource();

dataSource.setDriverClassName(driverClassName);

dataSource.setUrl(url);

dataSource.setUsername(dbUsername);

dataSource.setPassword(dbPassword);

return dataSource; }

}

CREATE TABLE companydb.employee ( id INTEGER UNSIGNED NOT NULL AUTO_INCREMENT, name VARCHAR(45) NOT NULL, surname VARCHAR(45) NOT NULL, title VARCHAR(45) NOT NULL, created timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, PRIMARY KEY (id) );

Output:

1 row inserted. 1 row inserted.

This was an example of how to insert a record to the database using the JdbcTemplate class provided by the Spring Framework in Java.

Photo of Byron Kiourtzoglou

Byron is a master software engineer working in the IT and Telecom domains. He is an applications developer in a wide variety of applications/services. He is currently acting as the team leader and technical architect for a proprietary service creation and integration platform for both the IT and Telecom industries in addition to a in-house big data real-time analytics solution. He is always fascinated by SOA, middleware services and mobile development. Byron is co-founder and Executive Editor at Java Code Geeks.