This example presents the basic concept of running DML operations in Spring JDBC.
The technologies used are :
-
– Spring 4.3.18
– H2 1.3
– Lombok 1.18
– JDK 1.80
– Maven 3.3.9
You can convert this example to an Eclipse IDE project by going to folder where is the pom.xml is, and use the command :
mvn eclipse:eclipse
Inspired from « Beginning Spring » Mert Caliskan, Kenan Sevindik, Rod Johnson (Foreword by), Jürgen Höller (Foreword by).
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>javaspringexamples.springJDBC.dmlOperations</groupId> <artifactId>dmlOperations</artifactId> <version>0.0.1-SNAPSHOT</version> <properties> <maven.compiler.source>1.8</maven.compiler.source> <maven.compiler.target>1.8</maven.compiler.target> </properties> <dependencies> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>4.3.18.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>4.3.18.RELEASE</version> </dependency> <dependency> <groupId>com.h2database</groupId> <artifactId>h2</artifactId> <version>1.3.175</version> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.18.6</version> </dependency> </dependencies> </project>
package javaspringexamples.springJDBC.dmlOperations; import javax.sql.DataSource; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.jdbc.datasource.DriverManagerDataSource; import org.springframework.jdbc.object.MappingSqlQuery; import org.springframework.jdbc.object.SqlUpdate; /** * * @author mounir.sahrani@gmail.com * */ @Configuration public class Conf { @Bean public DataSource dataSource() { DriverManagerDataSource dataSource = new DriverManagerDataSource(); dataSource.setDriverClassName("org.h2.Driver"); dataSource.setUrl("jdbc:h2:tcp://localhost/~/javaspringexamples"); dataSource.setUsername("sa"); dataSource.setPassword(""); return dataSource; } @Bean public JdbcTemplate jdbcTemplate() { JdbcTemplate jdbcTemplate = new JdbcTemplate(); jdbcTemplate.setDataSource(dataSource()); return jdbcTemplate; } @Bean public UserDao userDao() { UserDaoJdbcImpl userDao = new UserDaoJdbcImpl(); userDao.setJdbcTemplate(jdbcTemplate()); userDao.setUserByIdQuery(userByIdQuery()); userDao.setUserInsert(userInsert()); userDao.setUserUpdate(userUpdate()); userDao.setUserDelete(userDelete()); return userDao; } @Bean public MappingSqlQuery<User> userByIdQuery() { UserFindByIdQuery query = new UserFindByIdQuery(dataSource()); return query; } @Bean public SqlUpdate userInsert() { UserInsert userInsert = new UserInsert(dataSource()); return userInsert; } @Bean public SqlUpdate userUpdate() { UserUpdate userUpdate = new UserUpdate(dataSource()); return userUpdate; } @Bean public SqlUpdate userDelete() { UserDelete userDelete = new UserDelete(dataSource()); return userDelete; } }
package javaspringexamples.springJDBC.dmlOperations; import org.springframework.dao.DataAccessException; /** * * @author mounir.sahrani@gmail.com * */ public class ExceptionDeleteFailed extends DataAccessException { public ExceptionDeleteFailed(String msg) { super(msg); } }
package javaspringexamples.springJDBC.dmlOperations; import org.springframework.dao.DataAccessException; /** * * @author mounir.sahrani@gmail.com * */ public class ExceptionInsertFailed extends DataAccessException { public ExceptionInsertFailed(String msg) { super(msg); } }
package javaspringexamples.springJDBC.dmlOperations; import org.springframework.dao.DataAccessException; /** * * @author mounir.sahrani@gmail.com * */ public class ExceptionUpdateFailed extends DataAccessException { public ExceptionUpdateFailed(String msg) { super(msg); } }
package javaspringexamples.springJDBC.dmlOperations; import java.sql.SQLException; import org.springframework.context.annotation.AnnotationConfigApplicationContext; /** * * @author mounir.sahrani@gmail.com * */ public class Main { public static void main(String[] args) throws SQLException { AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext(Conf.class); UserDao userDao = applicationContext.getBean(UserDao.class); User user = new User(); user.setName("Wow"); user.setUserName("Wiw"); user.setLocked(true); userDao.insert(user); user = userDao.find(user.getId()); System.out.println(user.getId() + "," + user.getName() + "," + user.getUserName() + "," + user.isLocked()); user.setLocked(false); userDao.update(user); user = userDao.find(user.getId()); System.out.println(user.isLocked()); userDao.delete(user.getId()); user = userDao.find(user.getId()); System.out.println(user); } }
package javaspringexamples.springJDBC.dmlOperations; import java.util.Date; import lombok.Data; import lombok.ToString; /** * * @author mounir.sahrani@gmail.com * */ @Data public class User { private long id; private String name; private String userName; @ToString.Exclude private Date accessTime; private boolean locked; }
package javaspringexamples.springJDBC.dmlOperations; /** * * @author mounir.sahrani@gmail.com * */ public interface UserDao { public void insert(User user); public void update(User user); public void delete(long userId); public User find(long userId); }
package javaspringexamples.springJDBC.dmlOperations; import java.sql.ResultSet; import java.sql.SQLException; import java.util.Collections; import java.util.List; import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.jdbc.core.RowMapper; import org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate; import org.springframework.jdbc.object.MappingSqlQuery; import org.springframework.jdbc.object.SqlUpdate; import org.springframework.jdbc.support.GeneratedKeyHolder; /** * * @author mounir.sahrani@gmail.com * */ public class UserDaoJdbcImpl implements UserDao { private JdbcTemplate jdbcTemplate; private NamedParameterJdbcTemplate namedParameterJdbcTemplate; private MappingSqlQuery<User> userByIdQuery; private SqlUpdate userInsert; private SqlUpdate userUpdate; private SqlUpdate userDelete; public void setUserInsert(SqlUpdate userInsert) { this.userInsert = userInsert; } public void setUserUpdate(SqlUpdate userUpdate) { this.userUpdate = userUpdate; } public void setUserDelete(SqlUpdate userDelete) { this.userDelete = userDelete; } public void setUserByIdQuery(MappingSqlQuery<User> userByIdQuery) { this.userByIdQuery = userByIdQuery; } public void setJdbcTemplate(JdbcTemplate jdbcTemplate) { this.jdbcTemplate = jdbcTemplate; namedParameterJdbcTemplate = new NamedParameterJdbcTemplate(jdbcTemplate); } public void insert(User user) { GeneratedKeyHolder keyHolder = new GeneratedKeyHolder(); int count = userInsert.update(new Object[] { user.getName(), user.getUserName(), user.isLocked() }, keyHolder); if (count != 1) throw new ExceptionInsertFailed("Cannot insert user"); user.setId(keyHolder.getKey().longValue()); } public void update(User user) { int count = userUpdate.update(user.getName(), user.getUserName(), user.isLocked(), user.getId()); if (count != 1) throw new ExceptionUpdateFailed("Cannot update user"); } public void delete(long userId) { int count = userDelete.update(userId); if (count != 1) throw new ExceptionDeleteFailed("Cannot delete user"); } public User find(long userId) { return userByIdQuery.findObject(userId); } }
package javaspringexamples.springJDBC.dmlOperations; import java.sql.Types; import javax.sql.DataSource; import org.springframework.jdbc.core.SqlParameter; import org.springframework.jdbc.object.SqlUpdate; /** * * @author mounir.sahrani@gmail.com * */ public class UserDelete extends SqlUpdate { public UserDelete(DataSource dataSource) { super(dataSource, "delete user where id = ?"); setParameters(new SqlParameter[]{new SqlParameter(Types.BIGINT)}); compile(); } }
package javaspringexamples.springJDBC.dmlOperations; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Types; import javax.sql.DataSource; import org.springframework.jdbc.core.SqlParameter; import org.springframework.jdbc.object.MappingSqlQuery; /** * * @author mounir.sahrani@gmail.com * */ public class UserFindByIdQuery extends MappingSqlQuery<User> { public UserFindByIdQuery(DataSource dataSource) { super(dataSource, "select id,name,user_name,locked from user where id = ?"); declareParameter(new SqlParameter(Types.BIGINT)); compile(); } @Override protected User mapRow(ResultSet rs, int rowNum) throws SQLException { User user = new User(); user.setId(rs.getLong("id")); user.setName(rs.getString("name")); user.setUserName(rs.getString("user_name")); user.setLocked(rs.getBoolean("locked")); return user; } }
package javaspringexamples.springJDBC.dmlOperations; import java.sql.Types; import javax.sql.DataSource; import org.springframework.jdbc.core.SqlParameter; import org.springframework.jdbc.object.SqlUpdate; /** * * @author mounir.sahrani@gmail.com * */ public class UserInsert extends SqlUpdate { public UserInsert(DataSource dataSource) { super(dataSource, "insert into user(name,user_name,locked) values(?,?,?)"); setParameters(new SqlParameter[] { new SqlParameter(Types.VARCHAR), new SqlParameter(Types.VARCHAR), new SqlParameter(Types.BOOLEAN) }); setReturnGeneratedKeys(true); setGeneratedKeysColumnNames(new String[] { "id" }); compile(); } }
package javaspringexamples.springJDBC.dmlOperations; import java.sql.Types; import javax.sql.DataSource; import org.springframework.jdbc.core.SqlParameter; import org.springframework.jdbc.object.SqlUpdate; /** * * @author mounir.sahrani@gmail.com * */ public class UserUpdate extends SqlUpdate { public UserUpdate(DataSource dataSource) { super(dataSource, "update user set (name,user_name, locked) = (?,?,?) where id=?"); setParameters(new SqlParameter[] { new SqlParameter(Types.VARCHAR), new SqlParameter(Types.VARCHAR), new SqlParameter(Types.BOOLEAN), new SqlParameter(Types.BIGINT) }); compile(); } }
Get the sources of the example from the following GitHub url