• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

jpql size에서 질문이 있습니다!

23.04.25 15:47 작성 조회수 398

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

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

try {

    Team team = new Team();
    team.setName("teamA");
    em.persist(team);

    Member member = new Member();
    member.setUsername(" 유저  ");
    member.setAge(10);
    member.setTeam(team);
    member.setMemberType(MemberType.ADMIN);

    em.persist(member);

    em.flush();
    em.clear();

    String query = "select size(t.members) from Team t";

    List<Integer> resultList =
            em.createQuery(query, Integer.class).getResultList();
    System.out.println(resultList.size());
    for (Integer s : resultList) {
                System.out.println("s = " + s);
            }

    tx.commit();
}

코드는 위와 같이 작성하였습니다. 실제로 팀을 하나 넣었고 count가 1로 측정되는 것을 확인해보고 싶어서 테스트해 보았는데

java.lang.ClassCastException: class [Ljava.lang.Object; cannot be cast to class java.lang.Integer ([Ljava.lang.Object; and java.lang.Integer are in module java.base of loader 'bootstrap')

at org.example.Main.main(Main.java:36)

위와 같은 에러가 발생햇습니다. Team에 멤버가 들어 있는것도 확인을 하였고 resultList가 for문 안에서 돌면서 등록된 게 하나 이니까 1이 출력될 것이라 예상햇는데 ClassCastException이 발생하더군요.

여러가지 생각해 보았는데 답이 나오질 않아서 질문드립니다!

제가 어딘가 잘못 사용하고 있는 것일까요??

답변 1

답변을 작성해보세요.

0

David님의 프로필

David

2023.04.27

안녕하세요. J LEE님, 공식 서포터즈 David입니다.
잘못 작성한 부분은 없어 보이는데 프로젝트 내 코드를 살펴보아야 할 것 같습니다.

아래 가이드를 따라 프로젝트를 공유해 주세요:)


전체 프로젝트를 압축한 뒤
구글 드라이브로 공유해서 링크를 남겨주세요.

1. 구글 드라이브 업로드 방법

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

2. 주의사항
구글 드라이브 공유시
권한을 반드시 확인해주세요

3. 아래 내용을 작성 부탁드립니다.
a. 프로젝트 실행 방법을 알려주세요.
b. 어떻게 문제를 확인할 수 있는지 자세한 설명을 남겨주세요.

감사합니다.