2013년 7월 27일 토요일

(Spring3.2 Board) Spring 3.2에서 게시판 작성하기[6. Spring DAO 만들기]

(Spring3.2 Board) Spring 3.2에서 게시판 작성하기[6. DAO 만들기]

구로디지털 오엔제이프로그래밍실무교육센터


데이터베이스 SQL문장을 실행하기 위한 DAO클래스를 만들어 보자.
우선 BoardDAO라는 인터페이스를 만든 이를 구현한 SpringBoardDAO 만들자. SpringBoardDAO configBoard.xml 파일에서 빈으로 등록되어 스프링 프레임워크가 기동될 WebApplicationContext 의해 boardDAO라는 이름의 빈으로 등록되어 서비스 된다.:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" /><?XML:NAMESPACE PREFIX = O />
BoardDAO 인터페이스 에서는 게시판 리스트 보기를 위한 boardList() 정의한다.
[BoardDAO.java]
package onj.board.dao;
import java.util.List;
import onj.board.model.BoardDTO;
import org.springframework.dao.DataAccessException;
public interface BoardDAO {
       public List<BoardDTO> boardList() throws DataAccessException;
}
아래 SpringBoardDAO에서 setDataSource 통해 DataSource 세터주입 받는데  boardConfig.xml 다음 구문에 의해 주입 받는다.
(property name값에 대한 set method 있어야 하는데 SpringBoardDAO setDataSource 메소드가 정의되어 있어야 한다.)
<bean id="boardDAO"  class="onj.board.dao.SpringBoardDAO">
             <property name="dataSource">
                    <ref bean="dataSource"/>
             </property>
       </bean>
Spring DI 하나인 세터주입(Setter Inject) 대해서는 다음 URL 참고하자.
jdbcTemplate객체의 query 명령문에 의해 SELECT문장을 실행하며 인자로 넘겨 RowMapper maprow 구현에 의해 실행된 결과를 건씩 BoardDTO 담으며 최종 결과물을 boardList 담아서 리턴해 준다. 모든 게시물을 읽기 위해서 new RowMapper()에서 mapRow 구현 것이다.
다음은 전체 소스코드이다.
[SpringBoardDAO.java]
package onj.board.dao;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;
import javax.sql.DataSource;
import onj.board.model.BoardDTO;
import org.springframework.dao.DataAccessException;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;
public class SpringBoardDAO implements BoardDAO {
       private JdbcTemplate jdbcTemplate;
      
       public void setDataSource(DataSource dataSource){              
                    this.jdbcTemplate = new JdbcTemplate(dataSource);
       }
 
       @Override
       public List<BoardDTO> boardList() throws DataAccessException {
             List<BoardDTO> boardList = null;
            
             String sql = "select * from board";
            
             boardList = jdbcTemplate.query(sql, 
                                 new RowMapper() {
                           public Object mapRow(ResultSet rs, int rowNum) throws SQLException {
       BoardDTO board = new BoardDTO();
                                             
                                              board.setSeq(rs.getInt("seq"));                                          board.setName(rs.getString("name"));                                     board.setPasswd(rs.getString("passwd"));                                 board.setTitle(rs.getString("title"));                                   board.setContent(rs.getString("content"));                               board.setFileName(rs.getString("filename"));
       board.setDate(rs.getString("regdate"));
       board.setReadCount(rs.getInt("readcount"));
       board.setReply(rs.getInt("reply"));
       board.setReply_step(rs.getInt("reply_step"));
       board.setReply_level(rs.getInt("reply_level"));
                                             
       return board;
                                        }
             });
            
             return boardList;
       }
}

댓글 없음:

댓글 쓰기