• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

상품등록 조회가 되지 않아요

23.05.01 18:38 작성 23.05.01 18:41 수정 조회수 265

0



[질문 내용]
여기에 질문 내용을 남겨주세요.

회원가입과 회원 조회는 문제없이 되는데

상품등록은 작성은 되지만 db에 담기지도 않고 그래서 조회도 안됩니다 ㅠㅠ 상품등록 조회 영상 코드가 잘못인가 하고 복붙을 했는데도 안됩니다 ㅠㅠ

무엇이 문제일까요??ㅠㅠ]

제가 지금 야생형으로 따라 하고있어서 아무것도 몰라서 어느부분이 문제인지 알수없어서 남겨봅니다

답변 2

·

답변을 작성해보세요.

0

y2gcoder님의 프로필

y2gcoder

2023.05.02

안녕하세요, deal6162 님. 공식 서포터즈 y2gcoder 입니다.

보내주신 코드 확인해보았습니다!

원인은 ItemService의 saveItem() 에 @Transactional을 붙여주지 않아서 그렇습니다.

@Service
@Transactional(readOnly = true)
@RequiredArgsConstructor
public class ItemService {

    private final ItemRepository itemRepository;

    @Transactional // 추가!
    public void saveItem(Item item) {
        itemRepository.save(item);
    }

    public List<Item> findItems() {
        return itemRepository.findAll();
    }
    public Item findOne(Long itemId) {
        return itemRepository.findOne(itemId);
    }
}

원인에 대해 간단하게만 부연설명을 드리자면, 클래스 단에 추가한 @Transactional(readOnly = true)는 읽기 전용 트랜잭션이기 때문에, DB에 쓰기 작업(insert, update, delete query)을 할 수 없습니다. 그래서 DB에 쓰기 작업이 필요한 saveItem()는 따로 readOnly 옵션 값을 주지 않은 (속성 기본값이 false입니다) @Transactional을 붙여 옵션을 덮어씌워주면 정상적으로 DB에 쓰기 작업을 할 수 있게 되어 원하시는대로 상품 등록을 할 수 있습니다.



감사합니다.

deal6162님의 프로필

deal6162

질문자

2023.05.02

어떻게 찾은신건가요???ㅠㅠ

y2gcoder님의 프로필

y2gcoder

2023.05.02

저는

  1. 직접 실행해서 말씀하신 사항 확인

  2. 캡처해주신 로그와 제 로그를 모두 확인했을 때 insert 쿼리가 날아가지 않는 것을 발견

  3. 디버깅을 통해 컨트롤러부터 서비스, 리포지토리 까지 들어가면서 강의 자료의 코드와 비교

이런 과정을 통해 발견했습니다.

원래 스스로 짠 코드는 스스로 디버깅하기 어려운 것 같습니다 :)

0

y2gcoder님의 프로필

y2gcoder

2023.05.02

안녕하세요, deal6162 님. 공식 서포터즈 y2gcoder 입니다.

상품 등록 부분에서 진행이 되지 않으셔서 질문을 주셨습니다.

로그에서는 insert query가 발생하지 않는다는 것을 제외하고는 알 수 있는 게 없어 문제 해결이 어려울 것 같습니다.
상품 등록과 관련된 코드(controller, service, repository, application.yml)들을 올려주시거나, 전체 코드를 올려주셔야 할 것 같습니다.

전체 코드를 올려주시는 방법은 아래와 같습니다 :)

전체 프로젝트를 압축해서 구글 드라이브로 공유해서 링크를 남겨주세요.
구글 드라이브 업로드 방법은 다음을 참고해주세요.

구글 드라이브 업로드 방법 링크

주의: 업로드시 권한 문제 꼭 확인해주세요

추가로 다음 내용도 코멘트 부탁드립니다.

1. 실행 방법을 알려주세요.
2. 어떻게 문제를 확인할 수 있는지 자세한 설명을 남겨주세요.

감사합니다.