inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

자바 ORM 표준 JPA 프로그래밍 - 기본편

기본 키 매핑

MEMBER_SEQ를 2번 호출 하는 이유

493

작성자 없음

작성한 질문수 0

0

처음 호출 하면 51개로 맞추고 그 다음부터, 메모리에서 사용한다고 하는데 이렇게 하는 이유가 무엇인가요 ?

 

처음 호출 할때 50개를 미리 세팅 하고 1번부터 사용하면 안되나요???

java JPA

답변 1

0

김영한

안녕하세요. hjemsti님

시퀀스를 새로 생성하고 DB에서 딱 한번만 시퀀스를 직접 호출하고, 현재 시퀀스 숫자를 보시면 이유를 아실 수 있을거에요^^

감사합니다.

0

pyeongsaengcoding

혹시 영한선생님께 1:1 질문이나 비밀 질문 같은 것은 할 수 없나요 ??

0

김영한

hjemsti님 비슷한 고민을 하는 다른 분들께도 도움이 되었으면 하기에, 공개 Q&A만 운영하고 있습니다.

감사합니다.

 

0

궁금이

저는 ddl auto를 create로 하고

시퀀스 전략 했을 때,

persist 안하고 봐도

 

시퀀스가 그냥 1,

증가가 50입니다..

그 다음 persist를 한번 해 봤더니,

next value for member_seq를 한번만 호출했습니다.

 

근데 persist 2번 이상하면,

next value for member_seq를 2번 호출합니다.

시퀀스의 현재값도 101번이 됩니다.

뭔가 JPA쪽에서 놓친건가요..?

아니면 제가 뭔가 강의에서 놓친건가요?

그렇게 현재값 101번 만든 후,

이번엔 dll.auto를 none으로 해서

다시 돌려봤더니 다서 persist 해서 테이블에 저장해서 나온 건 52부터 찍힙니다.

 

 

persist 안한 것

 

 

persist 1번

next value for member_seq 한번 호출

persist 2번 호출

next value for member_seq가 두번 호출 됍니다.

 

그런데.. 이 상태에서 ddl.auto를 none으로 하고 다시 한번 로직을 실행해 봤더니..

 

어.. 제 생각이 맞다면 101부터 id가 매겨져야 할 것 같은데.. 어..

 

     public static void main(String[] args) {
        EntityManagerFactory emf = Persistence.createEntityManagerFactory("hello");
        EntityManager em = emf.createEntityManager();
        EntityTransaction tx = em.getTransaction();

        tx.begin();

        try{
            Member member1 = new Member();
            member1.setUsername("A");
            Member member2 = new Member();
            member2.setUsername("B");
            Member member3 = new Member();
            member3.setUsername("C");

            em.persist(member1);
            em.persist(member2);
//            em.persist(member3);

            tx.commit();

        } catch (Exception e){
            tx.rollback();
        } finally {
            em.close();

        }

        emf.close();
    }

 

사용 버전

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>jpa-basic</groupId>
    <artifactId>ex-hello-jpa</artifactId>
    <version>1.0-SNAPSHOT</version>

    <properties>
        <maven.compiler.source>17</maven.compiler.source>
        <maven.compiler.target>17</maven.compiler.target>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.hibernate.orm</groupId>
            <artifactId>hibernate-core</artifactId>
            <version>6.2.9.Final</version>
        </dependency>

        <dependency>
            <groupId>com.h2database</groupId>
            <artifactId>h2</artifactId>
            <version>2.1.214</version>
        </dependency>

    </dependencies>

</project>

1

김영한

안녕하세요. 궁금이님

번거로우시겠지만 질문을 새로 남겨주시겠어요?

댓글로 질문을 남겨주시면 저희 서포터즈 분들이 도움을 드리기가 어렵습니다 ㅠㅠ

새로운 질문으로 부탁드려요 :)

벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?

0

57

2

inheritance startegy 선택시 고려사항

0

41

1

Entity 동등성 비교

0

47

1

실무 조언 관련 질문입니다.

0

68

1

H2데이터베이스 파일 생성

0

78

2

서브쿼리 강의에서 ALL 예시 관련 질문드립니다.

0

70

2

수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?

0

63

1

JPQL 메소드와 락

0

63

1

Delivery @OneToOne

0

71

1

17강 4~5분대 테이블 값 조회가 안됩니다.

0

104

2

UnsupportedOperationException 발생

0

97

3

H2 Database 연결이 안됩니다.

0

102

2

연관관계 매핑 질문드립니다.

0

95

2

h2데이터베이스 실행오류

0

116

2

persistence.xml

0

121

2

양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?

0

89

1

영속성 컨텍스트

0

75

1

JPA 프록시

0

107

1

Native Query와 MyBatis

0

83

1

영속성 컨텍스트는 어떤 메모리에 저장되는건가요?

0

97

1

임베디드 타입 예시 코드 관련 질문

0

126

3

명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요

0

103

3

인텔리제이 패키지 커서 단축키 질문

0

113

2

혹시 현재는 ID 데이터 타입이 String이면 안되나요?

0

154

1