package kr.or.ddit.controller.board;
import java.util.List;
import javax.inject.Inject;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import kr.or.ddit.service.IBoardService;
import kr.or.ddit.vo.Board;
import lombok.extern.slf4j.Slf4j;
@Controller
@RequestMapping("/crud/board")
@Slf4j
public class CrudBoardController {
@Inject
private IBoardService service;
@RequestMapping(value="/register", method = RequestMethod.GET)
public String crudRegisterForm(Model model) {
log.info("crudRegisterForm() 실행...!");
model.addAttribute("board", new Board());
return "crud/register";
}
@PostMapping(value="/register")
public String crudRegister(Board board, Model model) {
log.info("crudRegister() 실행...!");
service.register(board);
model.addAttribute("msg", "등록이 완료되었습니다.");
return "crud/success";
}
@RequestMapping(value="/list", method = RequestMethod.GET)
public String crudList(Model model) {
log.info("crudList() 실행...!");
List<Board> boardList = service.list();
model.addAttribute("boardList", boardList);
return "crud/list";
}
@RequestMapping(value="/read", method = RequestMethod.GET)
public String crudRead(int boardNo, Model model) {
log.info("crudRead() 실행...!");
Board board = service.read(boardNo);
model.addAttribute("board", board);
return "crud/read";
}
@RequestMapping(value="/modify", method = RequestMethod.GET)
public String crudModifyForm(int boardNo, Model model) {
log.info("crudModifyForm() 실행...!");
Board board = service.read(boardNo);
model.addAttribute("board", board);
model.addAttribute("status", "u"); // '수정을 진행중입니다'라는 flag값
return "crud/register";
}
@RequestMapping(value="/modify", method = RequestMethod.POST)
public String crudModify(Board board, Model model) {
log.info("crudModify() 실행...!");
service.update(board);
model.addAttribute("msg", "수정이 완료되었습니다");
return "crud/success";
}
@RequestMapping(value="/remove", method = RequestMethod.POST)
public String crudDelete(int boardNo, Model model){
log.info("crudDelete() 실행...!");
service.delete(boardNo);
model.addAttribute("msg", "삭제가 완료되었습니다");
return "crud/success";
}
**// 검색하기 메소드**
@RequestMapping(value="/search", method = RequestMethod.POST)
public String crudSearch(String title, Model model) {
log.info("crudSearch() 실행...!");
Board board = new Board();
board.setTitle(title);
List<Board> boardList = service.search(board);
model.addAttribute("board", board);
model.addAttribute("boardList", boardList);
return "crud/list";
}
}
interface로 먼저 IBoardSerivce를 생성하고 한다.
package kr.or.ddit.service.impl;
import java.util.List;
import javax.inject.Inject;
import org.springframework.stereotype.Service;
import kr.or.ddit.mapper.BoardMapper;
import kr.or.ddit.service.IBoardService;
import kr.or.ddit.vo.Board;
@Service
public class BoardServiceImpl implements IBoardService {
@Inject
private BoardMapper mapper;
@Override
public void register(Board board) {
mapper.create(board);
}
@Override
public List<Board> list() {
return mapper.list();
}
@Override
public Board read(int boardNo) {
return mapper.read(boardNo);
}
@Override
public int update(Board board) {
return mapper.update(board);
}
@Override
public void delete(int boardNo) {
mapper.delete(boardNo);
}
**// 검색하기 서비스**
@Override
public List<Board> search(Board board) {
return mapper.search(board);
}
}
interface로 root-context에 설정한 대로kr.or.ddit.mapper에 만들어 준다
package kr.or.ddit.mapper;
import java.util.List;
import kr.or.ddit.vo.Board;
public interface BoardMapper {
public void create(Board board);
public List<Board> list();
public Board read(int boardNo);
public int update(Board board);
public void delete(int boardNo);
public List<Board> search(Board board);
}
마이바티스는 동적 SQL을 조립하는 구조를 지원하고 있으며, SQL 조립 규칙을 매핑 파일에 정의할 수 있다.
1) 동적으로 SQL을 조립하기 위한 SQL 요소