DTO 와 DAO

DAO(Data Access Object)는 DB를 사용해 데이터를 조화하거나 조작하는 기능을
전담하도록 만든 오브젝트를 말한다.

사용자는 자신이 필요한 Interface를 DAO에게 던지고 DAO는 이 인터페이스를
구현한 객체를 사용자에게 편리하게 사용 할 수 있도록 반환해줍니다.

DB에 대한 접근을 DAO가 담당하도록 하여 데이터베이스 엑세스를 DAO에서만
하게 되면 다수의 원격호출을 통한 오버헤드를 VO나 DTO를 통해 줄일 수 있고
다수의 DB 호출문제를 해결할 수 있습니다. 또한 단순히 읽기만 하는 연산이므로
트랜잭션 간의 오버헤드를 감소할 수 있습니다.

DTO(Data Transfer Object)는 VO(Value Object)로 바꿔 말할 수 있는데
계층간 데이터 교환을 위한 자바빈즈를 말한다. 여기서 말하는 계층간의
컨트롤러, 뷰, 비즈니스 계층, 퍼시스턴스 계층을 말하며 각 계층간 데이터 교환을
위한 객체를 DTO 또는 VO라고 부른다.

대표적인 DTO로는 폼데이터빈, 데이터베이스 테이블빈 등이 있으며, 각 폼요소나,
데이터베이스 레코드의 데이터를 매핑하기 위한 데이터 객체를 말한다. 즉 폼 필드들의
이름을 그대로 가지고 있는 자바빈 객체를 폼 필드와 그대로 매핑하여 비즈니스 계층으로
보낼 때 사용하나다. 이런 객체를 DTO라고 부르며 VO(Value Object) 패턴이라고도 한다.
VO 패턴은 데이터 전달을 위한 가장 효율적인 방법이지만, 클래스 선언을 위해 많은
코드가 필요하다는 단점이 있다.

일반적인 DTO는 로직을 갖고 있지 않다. 순수한 데이터 객체이며 속상과 그 속성에
접근하기 위한 getter, setter 메소드만 가진 클래스를 말한다. 여기에 추가적으로
toString(), equals(), 등의 Object 클래스 메소드를 작성할 수 있다.

즉, 계층 간의 데이터 전달에 사용하는 데이터 객체들을 말한다.

1. DTO 클래스 예제

public class DTOBean {

private String name;

private int value;

private String data;

public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}

public int getValue() {
return value;
}

public void setValue(int value) {
this.value = value;
}

public String getData() {
return data;
}

public void setData(String data) {
this.data = data;
}
}

2. DAO 클래스 예제

//DB와 연결할 Connection을 가져온다.
//어떤 DB를 사용할 것이며, 어떤 드라이브와 로그인 정보를 사용할 것인가.
//작업이 끝나면 사용한 리소스를 시스템에 돌려준다.
public class TestDao {

public void add(DTOBean dto) throws ClassNotFoundException, SQLException{
Class.forName(“com.mysql.jdbc.Driver”);

Connection c= DriverManager.getConnection(“jdbc:mysql://localhost/springbook”, “spring”, “book”);

PreparedStatement ps = c.prepareStatement(“insert into users(id,name,password) value(?,?,?)”);

ps.setString(1, dto.getName());
ps.setInt(2, dto.getValue());
ps.setString(3, dto.getData());

ps.executeUpdate();

ps.close();
c.close();
}
}

웹 어플리케이션 구조 – 서비스~DAO 구조

웹 어플리케이션 개발할 때 가장 많이 사용되는 구조로 컨트롤러-서비스-DAO로 이어지는 구성이다.

모델 데이터베이스 테이블과 관련된 클래스가 위치한다. CRUD의 기본단위로 사용되며, 서비스-DAO 간 데이터를 주고 받기 위한 객체로도 사용된다.
DAO Data Access Object의 약자로 데이터베이스 테이블에 대한 CRUD 기능을 정의한다. 데이터 입력이나 수정, 조회 시 데이터 타입으로 모델을 사용한다.

Service에 의해 호출되어 쿼리를 담당하는 SqlMapClienTemplate 객체를 Spring으로부터 주입받아서,
SqlMapClientTemplate객체에 쿼리 수행을 위임하고, 처리 결과를 Service에 반환한다.

SQL의 CRUD에 해당하는 insert, select, update, delete 메소드를 정의한다.
DAO인터페이스는 조회 기준이 되는 테이블마다 1개를 작성하는 것이 일반적이다.

서비스 컨트롤러를 통해서 전달받은 사용자의 요청을 구현한다. DB연산이 필요한 경우 DAO를 이용한다.

Controller에 의해 호출되어 실제 비즈니스 로직과 트랜잭션을 처리하고, DB CRUD를 담당하는 DAO 객체를 Spring으로부터 주입 받아서, DAO에 DB CRUD처리를 위임하고 처리결과를 Controller에게 반환한다.

컨트롤러 사용자의 웹 요청을 받아 서비스나 DAO에 전달하고, 결과를 뷰에 전달한다.

HttpServletRequest를 이용한 요청 파라미터 구하기

@RequestMapping 메소드에  HttpServletRequest 타입의 인자를 추가한 뒤,  getParameter()메소드를 이용해서 HTTP 요청 파라미터를 구하면 된다.

@Controller
	public class EventController {
	
	@RequestMapping(value="/event/create", method=RequestMethod.POST) //value = 경로 , method = HTTP전송방식
	public String list(HttpServletRequest request, Model model) throws IOException{ 
               String id = request.getParameter('id');
               if(id == null) return "member/registered";
	}
}