From 06379e5dfc39fca37fa096cc17bb04273303e594 Mon Sep 17 00:00:00 2001 From: kang-hyungu Date: Thu, 21 Sep 2023 14:11:58 +0900 Subject: [PATCH 1/3] =?UTF-8?q?=ED=8C=A8=ED=82=A4=EC=A7=80=20=EC=9C=84?= =?UTF-8?q?=EC=B9=98=20=EB=B3=80=EA=B2=BD=20=EB=B0=8F=20=EC=BD=94=EB=93=9C?= =?UTF-8?q?=20=EC=A0=95=EB=A6=AC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- study/src/main/java/aop/config/DataSourceConfig.java | 1 + study/src/main/resources/application.yml | 1 + 2 files changed, 2 insertions(+) diff --git a/study/src/main/java/aop/config/DataSourceConfig.java b/study/src/main/java/aop/config/DataSourceConfig.java index b27245b932..d64fc2ca2b 100644 --- a/study/src/main/java/aop/config/DataSourceConfig.java +++ b/study/src/main/java/aop/config/DataSourceConfig.java @@ -14,6 +14,7 @@ public class DataSourceConfig { public DataSource dataSource() { return new EmbeddedDatabaseBuilder() .setType(EmbeddedDatabaseType.H2) + .setName("test;DB_CLOSE_DELAY=-1;MODE=MYSQL;") .addScript("classpath:schema.sql") .build(); } diff --git a/study/src/main/resources/application.yml b/study/src/main/resources/application.yml index 84c31c77b5..b9451e1013 100644 --- a/study/src/main/resources/application.yml +++ b/study/src/main/resources/application.yml @@ -1,5 +1,6 @@ spring: jpa: + open-in-view: false show-sql: true generate-ddl: true hibernate: From c5e4217d1fbd562fdb3d6bb6a112b3301cb53524 Mon Sep 17 00:00:00 2001 From: Go-Jaecheol Date: Fri, 29 Sep 2023 23:48:35 +0900 Subject: [PATCH 2/3] =?UTF-8?q?feat:=20JdbcTemplate=20=EA=B5=AC=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../jdbc/core/JdbcTemplate.java | 57 +++++++++++++++++++ .../springframework/jdbc/core/RowMapper.java | 10 ++++ 2 files changed, 67 insertions(+) create mode 100644 jdbc/src/main/java/org/springframework/jdbc/core/RowMapper.java diff --git a/jdbc/src/main/java/org/springframework/jdbc/core/JdbcTemplate.java b/jdbc/src/main/java/org/springframework/jdbc/core/JdbcTemplate.java index 52a0d30a17..5161326e2f 100644 --- a/jdbc/src/main/java/org/springframework/jdbc/core/JdbcTemplate.java +++ b/jdbc/src/main/java/org/springframework/jdbc/core/JdbcTemplate.java @@ -2,8 +2,14 @@ import org.slf4j.Logger; import org.slf4j.LoggerFactory; +import org.springframework.dao.DataAccessException; import javax.sql.DataSource; +import java.sql.Connection; +import java.sql.PreparedStatement; +import java.sql.SQLException; +import java.util.ArrayList; +import java.util.List; public class JdbcTemplate { @@ -14,4 +20,55 @@ public class JdbcTemplate { public JdbcTemplate(final DataSource dataSource) { this.dataSource = dataSource; } + + public void update(final String sql, final Object... objects) { + try (final var connection = dataSource.getConnection(); + final var preparedStatement = prepareStatement(connection, sql, objects)) { + log.debug("query : {}", sql); + preparedStatement.executeUpdate(); + } catch (SQLException e) { + log.error(e.getMessage(), e); + throw new DataAccessException(e); + } + } + + public T queryForObject(final String sql, final RowMapper rowMapper, final Object... objects) { + try (final var connection = dataSource.getConnection(); + final var preparedStatement = prepareStatement(connection, sql, objects); + final var resultSet = preparedStatement.executeQuery()) { + log.debug("query : {}", sql); + if (resultSet.next()) { + return rowMapper.mapRow(resultSet); + } + return null; + } catch (SQLException e) { + log.error(e.getMessage(), e); + throw new DataAccessException(e); + } + } + + public List query(final String sql, final RowMapper rowMapper) { + try (final var connection = dataSource.getConnection(); + final var preparedStatement = connection.prepareStatement(sql); + final var resultSet = preparedStatement.executeQuery()) { + log.debug("query : {}", sql); + final var results = new ArrayList(); + while (resultSet.next()) { + results.add(rowMapper.mapRow(resultSet)); + } + return results; + } catch (SQLException e) { + log.error(e.getMessage(), e); + throw new DataAccessException(e); + } + } + + private PreparedStatement prepareStatement(final Connection connection, final String sql, final Object[] objects) + throws SQLException { + final var preparedStatement = connection.prepareStatement(sql); + for (int i = 0; i < objects.length; i++) { + preparedStatement.setObject(i + 1, objects[i]); + } + return preparedStatement; + } } diff --git a/jdbc/src/main/java/org/springframework/jdbc/core/RowMapper.java b/jdbc/src/main/java/org/springframework/jdbc/core/RowMapper.java new file mode 100644 index 0000000000..02165135cd --- /dev/null +++ b/jdbc/src/main/java/org/springframework/jdbc/core/RowMapper.java @@ -0,0 +1,10 @@ +package org.springframework.jdbc.core; + +import java.sql.ResultSet; +import java.sql.SQLException; + +@FunctionalInterface +public interface RowMapper { + + T mapRow(final ResultSet resultSet) throws SQLException; +} From 6294dfd4937e1c78cc8ea5ee101abec4016940fb Mon Sep 17 00:00:00 2001 From: Go-Jaecheol Date: Fri, 29 Sep 2023 23:49:51 +0900 Subject: [PATCH 3/3] =?UTF-8?q?feat:=20UserDao=20=EC=A4=91=EB=B3=B5=20?= =?UTF-8?q?=EC=A0=9C=EA=B1=B0=20=EB=B0=8F=20update,=20findAll,=20findByAcc?= =?UTF-8?q?ount=20=EA=B8=B0=EB=8A=A5=20=EA=B5=AC=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../main/java/com/techcourse/dao/UserDao.java | 104 +++--------------- 1 file changed, 18 insertions(+), 86 deletions(-) diff --git a/app/src/main/java/com/techcourse/dao/UserDao.java b/app/src/main/java/com/techcourse/dao/UserDao.java index d14c545f34..8b80ebd48c 100644 --- a/app/src/main/java/com/techcourse/dao/UserDao.java +++ b/app/src/main/java/com/techcourse/dao/UserDao.java @@ -2,120 +2,52 @@ import com.techcourse.domain.User; import org.springframework.jdbc.core.JdbcTemplate; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; +import org.springframework.jdbc.core.RowMapper; import javax.sql.DataSource; -import java.sql.Connection; -import java.sql.PreparedStatement; -import java.sql.ResultSet; -import java.sql.SQLException; import java.util.List; public class UserDao { - private static final Logger log = LoggerFactory.getLogger(UserDao.class); + private final RowMapper rowMapper = resultSet -> new User( + resultSet.getLong("id"), + resultSet.getString("account"), + resultSet.getString("password"), + resultSet.getString("email") + ); - private final DataSource dataSource; + private final JdbcTemplate jdbcTemplate; public UserDao(final DataSource dataSource) { - this.dataSource = dataSource; + this.jdbcTemplate = new JdbcTemplate(dataSource); } public UserDao(final JdbcTemplate jdbcTemplate) { - this.dataSource = null; + this.jdbcTemplate = jdbcTemplate; } public void insert(final User user) { final var sql = "insert into users (account, password, email) values (?, ?, ?)"; - - Connection conn = null; - PreparedStatement pstmt = null; - try { - conn = dataSource.getConnection(); - pstmt = conn.prepareStatement(sql); - - log.debug("query : {}", sql); - - pstmt.setString(1, user.getAccount()); - pstmt.setString(2, user.getPassword()); - pstmt.setString(3, user.getEmail()); - pstmt.executeUpdate(); - } catch (SQLException e) { - log.error(e.getMessage(), e); - throw new RuntimeException(e); - } finally { - try { - if (pstmt != null) { - pstmt.close(); - } - } catch (SQLException ignored) {} - - try { - if (conn != null) { - conn.close(); - } - } catch (SQLException ignored) {} - } + jdbcTemplate.update(sql, user.getAccount(), user.getPassword(), user.getEmail()); } public void update(final User user) { - // todo + final var sql = "update users set account = ?, password = ?, email = ? where id = ?"; + jdbcTemplate.update(sql, user.getAccount(), user.getPassword(), user.getEmail(), user.getId()); } public List findAll() { - // todo - return null; + final var sql = "select id, account, password, email from users"; + return jdbcTemplate.query(sql, rowMapper); } public User findById(final Long id) { final var sql = "select id, account, password, email from users where id = ?"; - - Connection conn = null; - PreparedStatement pstmt = null; - ResultSet rs = null; - try { - conn = dataSource.getConnection(); - pstmt = conn.prepareStatement(sql); - pstmt.setLong(1, id); - rs = pstmt.executeQuery(); - - log.debug("query : {}", sql); - - if (rs.next()) { - return new User( - rs.getLong(1), - rs.getString(2), - rs.getString(3), - rs.getString(4)); - } - return null; - } catch (SQLException e) { - log.error(e.getMessage(), e); - throw new RuntimeException(e); - } finally { - try { - if (rs != null) { - rs.close(); - } - } catch (SQLException ignored) {} - - try { - if (pstmt != null) { - pstmt.close(); - } - } catch (SQLException ignored) {} - - try { - if (conn != null) { - conn.close(); - } - } catch (SQLException ignored) {} - } + return jdbcTemplate.queryForObject(sql, rowMapper, id); } public User findByAccount(final String account) { - // todo - return null; + final var sql = "select id, account, password, email from users where account = ?"; + return jdbcTemplate.queryForObject(sql, rowMapper, account); } }