[Toy Project] 글 삭제 기능 추가 + ERD 수정 + 프론트 수정

이신영·2023년 4월 13일
0

Eternal Moments

목록 보기
4/14
post-thumbnail

깃허브링크
ERD링크

글 삭제기능

entity

public class DeletedBoard {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    private Long BoardId;
    private String title;
    private String content;
    private String writerNickname;
    private String writerUsername;

    private LocalDate createdDate;
    private int viewCount;
    private int likeCount;

}

Repository

@Transactional
@Repository
public interface BoardLikeRepository extends JpaRepository<BoardLike, Long> {
    Optional<BoardLike> findByBoardAndMember(Board board, Member member);
    void deleteByBoardId(Long BoardId);
}
  • 추천된 게시글 테이블도 제거하기위해 deleteByBoardId 추가
public interface DeletedBoardRepository extends JpaRepository<DeletedBoard, Long> {
}

Service

boardService.java

    public void deleteBoard(Long id){
        Board board = boardRepository.findById(id)
                .orElseThrow(()-> new IllegalArgumentException("해당 게시글이 없습니다."));
        DeletedBoard deletedBoard = new DeletedBoard();
        deletedBoard.setBoardId(board.getId());
        deletedBoard.setContent(board.getContent());
        deletedBoard.setTitle(board.getTitle());
        deletedBoard.setWriterNickname(board.getWriterNickname());
        deletedBoard.setWriterUsername(board.getWriterUsername());
        deletedBoard.setCreatedDate(board.getCreatedDate());
        deletedBoard.setLikeCount(board.getLikeCount());
        deletedBoard.setViewCount(board.getViewCount());
        deletedBoardRepository.save(deletedBoard);
        boardLikeRepository.deleteByBoardId(id);
        boardRepository.deleteById(id);
    }

Controller

BoardController.java

    @GetMapping("/board/delete/{id}")
    public ModelAndView BoardDelete(@PathVariable Long id)
    {
        boardService.deleteBoard(id);
       ModelAndView mav = new ModelAndView();
       mav.addObject("message","삭제되었습니다.");
       mav.setViewName("alert");
        mav.addObject("redirectPath", "/board/list");
       return mav;
    }

View

boardView.html

    <td colspan="2" class="btn-group">
      <form th:if="${isWriter}" id="like-button" method="post" th:action="@{/board/like/{id}(id=${board.id})}">
        <button type="submit" class="btn btn-success">추천</button>
      </form>
      <form id="back" method="get" th:action="@{/board/list}">
        <button type="submit" class="btn btn-primary">글 목록</button>
      </form>
      <form th:if="${isWriter}" id="update" method="get" th:action="@{/board/update/{id}(id=${board.id})}">
        <button type="submit" class="btn btn-warning">글 수정</button>
      </form>
      <form th:if="${isWriter}" id="delete" method="get" th:action="@{/board/delete/{id}(id=${board.id})}" onsubmit="return confirm('정말로 삭제하시겠습니까?')">
        <button type="submit" class="btn btn-primary">글 삭제</button>
      </form>
    </td>

기능

  • 글 삭제 버튼을 누르면

  • 삭제가 완료됨

ERD

수정사항

  • delete_board 테이블 추가. boardid : id(board) (1:1)
  • board 칼럼 writer를 writerNickname, writerUsername 으로 변경

프론트

  • 부트스트랩을 활용하고 nav를 모든 뷰에 추가

  • 홈페이지

  • 로그인

  • 게시판

  • 게시글 상세보기

후기

느낀점

  • 프론트가 사니까 좀 괜찮아졌다는게 느껴짐
  • 테이블마다 관계설정을 한 만큼 삭제, 수정에 오류가 없도록 정규화를 잘 해야된다고 느껴짐
  • 코드의 유지보수를 신경써야겠다고 느낌. OOP를 생활화하자..!

다음 해야할 것

  • 댓글기능
  • 문의기능
profile
후회하지 않는 사람이 되자 🔥

0개의 댓글