티스토리 뷰
[Spring] 스프링부트 + JPA + thymeleaf + Spring Security로 회원가입 + 게시판(수정, 삭제, 등록, 조회, 댓글, 좋아요) + 로그인 구현하기 #9 게시물 삭제하기
poopooreum 2024. 8. 31. 18:53✏️ 게시물 삭제 로직
- 유저가 삭제하기 버튼을 누른다
- 컨트롤러는 로그인 상태를 확인하고 로그인이 되어 있다면 boardService를 통해 게시물을 삭제한다.
- 로그인이 되어 있지 않다면 로그인 화면으로 리턴시킨다.
- boardService는 전달받은 idx를 통해 게시글이 존재하는지 확인하고 존재한다면 게시물을 삭제한다.
✏️ Api Controller 클래스
@PostMapping("/delete") // 글 삭제하기
public String delete(HttpServletRequest httpServletRequest, @RequestParam("idx") Long idx) {
HttpSession session = httpServletRequest.getSession(true);
Optional<Object> idOptional = Optional.ofNullable(session.getAttribute("userId"));
if (idOptional.isEmpty()) {
log.error("로그인을 하지 않으면 글을 삭제할 수 없습니다.");
return "redirect:/login";
}
boardService.delete(idx);
log.info("게시물 삭제");
return "redirect:/member/list";
}
로그인을 하지 않았다면 권한이 없으므로 로그인 화면으로 이동시키고 그게 아니라면
boardService를 통해 게시물을 삭제한다.
✏️ BoardService 인터페이스
void delete(Long idx);
✏️ BoardServiceImp 클래스
@Transactional
@Override
public void delete(Long idx) {
Optional<Board> board = boardRepository.findById(idx);
if (board.isPresent()) {
Board boardEntity = board.get();
log.error(board.get().toString());
likesRepository.deleteByBoardIdx(boardEntity);
commentRepository.deleteByBoardIdx(boardEntity);
boardRepository.deleteById(idx);
}
}
단순히 Board에 있는 게시글만 삭제한다고 생각할 수 있는데 그렇게 하게 되면 오류가 발생한다.
먼저 org.springframework.dao.DataIntegrityViolationException: could not execute statement; SQL [n/a]; constraint 이 발생한다. 맨 첫장에서 보면 Board와 Comment, Like는 1 : N의 연관 관계를 가지고 있다. 그러므로 연관 관계에 있는 DB들도 delete를 해 주어야 하는데 여기서도 순서가 있다. Board가 Comment, Likes보다는 상위 개념이기 때문에 하위 개념에 있는 것들부터 삭제를 해주어야 한다.
위 처럼만 하고 진행을 하면 삭제가 될 것 같지만 아래와 같은 오류가 발생한다.
no entitymanager with actual transaction available for current thread - cannot reliably process 'remove' call 이 오류는 @Transactional를 붙이면 해결할 수 있다. 아직 이 개념에 대해서는 공부 중이여서 궁금하다면 이 오류를 그대로 구글에 검색하면 될 것 같다.
✏️ LikesRepository 인터페이스
public interface LikesRepository extends JpaRepository<Likes, Long> {
void deleteByBoardIdx(Board board);
}
쿼리문 추가
✏️ CommentRepository 인터페이스
public interface CommentRepository extends JpaRepository<Comment, Integer> {
void deleteByBoardIdx(Board board);
}
쿼리문 추가
'Back-end > Spring' 카테고리의 다른 글
- Total
- Today
- Yesterday
- DP
- DFS
- 카운팅 정렬
- js
- html
- 알고리즘
- java
- CSS
- 반복문
- 자료구조
- Do it!
- C++
- 우선순위 큐
- 백준
- 이분 매칭
- 스프링 부트 crud 게시판 구현
- 자바스크립트
- 유클리드 호제법
- 알고리즘 공부
- 투 포인터
- 백준 풀이
- 유니온 파인드
- 에라토스테네스의 체
- C++ Stack
- BFS
- 자바
- 세그먼트 트리
- c++ string
- 스택
- HTML5
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |