(2/5) Item Entity, Repository, Test 실습 find+(Entity명)+By+(변수명) Method > 스프링 부트

본문 바로가기

[개발] (2/5) Item Entity, Repository, Test 실습 find+(Entity명)+By+(변수명) Method

필기자
2022-09-08 16:22 6,833 0

본문

Item Entity, Repository, Test 실습 find+(Entity명)+By+(변수명) Method

 

kr/hull/shop/repository/ItemRepository.java 다음 내용 추가



public interface ItemRepository extends JpaRepository<Item, Long> {
    List<Item> findByItemNm(String itemNm); // find+(Entity명)+By+(변수명)으로 메소드 생성. Entity명 제거할 수 있음
    // List<Item> findItemByItemNm(String itemNm);
}

 

src/test/java/kr/hull/shop/repository/ItemRepositoryTest.java 다음 내용 추가



@SpringBootTest // 테스트 실행시 모든 Bean을 IoC 컨테이너에 등록 = 스프링부트 구동과 동일한 환경 조건
@TestPropertySource(locations="classpath:application-test.properties") // 테스트 실행시 우선되는 설정파일
class ItemRepositoryTest {
    @Autowired // 필드 Bean 주입
    ItemRepository itemRepository;

    @Test // Method 테스트 대상 지정
    @DisplayName("상품 저장 확인") // 테스트명
    public void createItemTest(){
        Item item = new Item();
        item.setItemNm("좋은 상품");
        item.setPrice(10000);
        item.setItemDetail("좋은 상품 설명");
        item.setItemSellStatus(ItemSellStatus.SELL);
        item.setStockNumber(100);
        item.setRegTime(LocalDateTime.now());
        item.setUpdateTime(LocalDateTime.now());
        Item savedItem = itemRepository.save(item);
        System.out.println(savedItem.toString());
    }

    public void createItemList(){
        for(int i=1; i<=10; i++){
            Item item = new Item();
            item.setItemNm("좋은 상품 " + i);
            item.setPrice(10000 + i);
            item.setItemDetail("좋은 상품 설명 " + i);
            item.setItemSellStatus(ItemSellStatus.SELL);
            item.setStockNumber(100); item.setRegTime(LocalDateTime.now());
            item.setUpdateTime(LocalDateTime.now());
            itemRepository.save(item);
        }
    }

    @Test
    @DisplayName("상품명 조회 확인")
    public void findByItemNmTest(){
        this.createItemList();
        List<Item> itemList = itemRepository.findByItemNm("좋은 상품 7");
        for(Item item : itemList){
            LOGGER.info(item.toString());
        }
    }
}

 

결과

 

20220908162144_ddfa29dc4cb6a70c618839d7aa582e62_oj28.png

 

DB 확인

 

20220908162222_ddfa29dc4cb6a70c618839d7aa582e62_cy63.png

 

댓글목록0

등록된 댓글이 없습니다.
게시판 전체검색