
리팩토링 하기전의 중복 부분이 많은 코드.
이후의 글에서 점차 리팩토링 해가는 모습을 남기겠습니다.
1. DbUserRepository
@Primary
@Repository
public class DbUserRepository implements UserRepository {
    private final DataSource dataSource;
    public DbUserRepository(DataSource dataSource) {
        this.dataSource = dataSource;
    }
    @Override
    public Long save(User user) {
        String SQL = "INSERT INTO user_info (user_id, password, name, email) VALUES (?, ?, ?, ?)";
        Connection connection = null;
        PreparedStatement pstmt = null;
        ResultSet rs = null;
        try {
            connection = getConnection();
            pstmt = connection.prepareStatement(SQL, Statement.RETURN_GENERATED_KEYS);
            pstmt.setString(1, user.getUserId());
            pstmt.setString(2, user.getPassword());
            pstmt.setString(3, user.getName());
            pstmt.setString(4, user.getEmail());
            pstmt.executeUpdate();
            rs = pstmt.getGeneratedKeys();
            if (rs.next()) {
                user.setId(rs.getLong(1));
                return user.getId();
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }finally {
            DbCleaner.close(connection, pstmt, rs, dataSource);;
        }
        return -1L;
    }
    @Override
    public Optional<User> findByUserId(String userId) {
        String SQL = "SELECT id, user_id, password, name, email FROM user_info WHERE user_id = (?)";
        Connection connection = null;
        PreparedStatement pstmt = null;
        ResultSet rs = null;
        try {
            connection = getConnection();
            pstmt = connection.prepareStatement(SQL);
            pstmt.setString(1, userId);
            rs = pstmt.executeQuery();
            while(rs.next()){
                User user = new User(rs.getString("user_id"), rs.getString("password"), rs.getString("name"), rs.getString("email"));
                user.setId(rs.getLong("id"));
                return Optional.ofNullable(user);
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }finally {
            DbCleaner.close(connection, pstmt, rs, dataSource);
        }
        return Optional.empty();
    }
    @Override
    public List<User> findAll() {
        String SQL = "SELECT id, user_id, password, name, email FROM user_info";
        Connection connection = null;
        PreparedStatement pstmt = null;
        ResultSet rs = null;
        List<User> list = new ArrayList<>();
        try {
            connection = getConnection();
            pstmt = connection.prepareStatement(SQL);
            rs = pstmt.executeQuery();
            while(rs.next()){
                User user = new User(rs.getString("user_id"), rs.getString("password"), rs.getString("name"), rs.getString("email"));
                user.setId(rs.getLong("id"));
                list.add(user);
            }
            return list;
        } catch (SQLException e) {
            e.printStackTrace();
        }finally {
            DbCleaner.close(connection, pstmt, rs, dataSource);
        }
        return list;
    }
    @Override
    public boolean delete(String userId) {
        String SQL = "DELETE FROM user_info WHERE user_id = (?)";
        Connection connection = null;
        PreparedStatement pstmt = null;
        ResultSet rs = null;
        try {
            connection = getConnection();
            pstmt = connection.prepareStatement(SQL);
            pstmt.setString(1, userId);
            int affectedLine = pstmt.executeUpdate();
            if(affectedLine == 1){
                return true;
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }finally {
            DbCleaner.close(connection, pstmt, rs, dataSource);
        }
        return false;
    }
    @Override
    public boolean update(String userId, User updateParam) {
        String SQL = "UPDATE user_info SET user_id = (?), password = (?), name = (?), email = (?) WHERE user_id = (?)";
        Connection connection = null;
        PreparedStatement pstmt = null;
        ResultSet rs = null;
        try {
            connection = getConnection();
            pstmt = connection.prepareStatement(SQL);
            pstmt.setString(1, updateParam.getUserId());
            pstmt.setString(2, updateParam.getPassword());
            pstmt.setString(3, updateParam.getName());
            pstmt.setString(4, updateParam.getEmail());
            pstmt.setString(5, updateParam.getUserId());
            int affectedLine = pstmt.executeUpdate();
            if(affectedLine == 1){
                return true;
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }finally {
            DbCleaner.close(connection, pstmt, rs, dataSource);
        }
        return false;
    }
    private Connection getConnection() {
        return DataSourceUtils.getConnection(dataSource);
    }
}
2. DbCleaner
public class DbCleaner {
    public static void close(Connection conn, PreparedStatement pstmt, ResultSet rs, DataSource dataSource) {
        try {
            if (rs != null) {
                rs.close();
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
        try {
            if (pstmt != null) {
                pstmt.close();
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
        try {
            if (conn != null) {
                close(conn, dataSource);
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
    private static void close(Connection conn, DataSource dataSource) throws SQLException {
        DataSourceUtils.releaseConnection(conn, dataSource);
    }
}'BackEnd > JDBC' 카테고리의 다른 글
| [JDBC] DAO 리팩토링 2 - 하나의 Template 으로 이동 (0) | 2022.03.13 | 
|---|---|
| [JDBC] DAO 리팩토링 1 - 개별 Template 만들기 (0) | 2022.03.12 | 
| [JDBC] PrepareStatement에서 TimeStamp, LocalDateTime 사용하기 (0) | 2022.03.06 | 
| [JDBC] INSERT에 대한 자동 생성 키 값 검색하기 (0) | 2022.03.04 | 
| [oracle] oracle 19c scott 계정 활성화 (13) | 2022.02.07 | 
 
			
			
				
댓글