«   2024/12   »
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30 31
Tags
more
Archives
Today
Total
관리 메뉴

올해는 머신러닝이다.

초난감DAO 리팩토링 1단계 ****커넥션 만들기의 추출**** 본문

스프링프레임워크공부중/1부 초난감DAO 리팩토링

초난감DAO 리팩토링 1단계 ****커넥션 만들기의 추출****

행복한 수지아빠 2010. 12. 16. 11:48
이전 UserDao 클래스에서 add() 안의 메소드를 보면 세가지 관심사항을 발견할 수 있다.

UserDao의 관심사항
1.DB와 연결을 위한 커넥션을 어떻게 가져올까라는 관심
2.사용자 등록을 위해 DB에 보낼 SQL문장을 담을 Statement를 만들고 실행하는 것
3.작업이 끝나면 사용한 리소스를 닫아주는 일

public void add(User user) throws ClassNotFoundException,SQLException{
Connection c = getConnection();
String sql = "insert into users(id,name,password) values(?,?,?)";
PreparedStatement ps = c.prepareStatement(sql);
                .....

아래 메소드를 추가함으로써 add와 get에서 중복되는 커넥션 부분을 추출했다.
private Connection getConnection() throws ClassNotFoundException,SQLException{
Class.forName("org.gjt.mm.mysql.Driver");
return DriverManager.getConnection("jdbc:mysql://localhost/springbook","root","1234");
}

이정도는 금방 이해가 될꺼라 본다...하지만 다음단계부터 중요해짐.^^