id가 +1씩 증가 안하고 갑자기 34 35 로 뛰는 현상
313
작성한 질문수 51

이전 강의 따라 진행할때도 id가 1, 2, 34 이렇게 숫자가 갑자기 증가해서 실수한 줄 알고 테이블 드랍 후 진행했었는데 다음 강의 따라 진행하는 과정에서도 이 문제가 발생합니다!
이번 강의에서는 delete from member 로 테이블 데이터를 날리기 전부터 이 문제가 발생했고 무시하고 진행한 후 테스트하는 과정에서도 이렇게 숫자가 급격하게 증가해버리네요...
어떤 부분에서 문제가 생긴걸까요...?
답변 1
1
안녕하세요, 인프런 AI 인턴입니다.
루피님, 데이터베이스에서 ID 값이 연속적으로 증가하지 않고 건너뛰는 현상이 있다고 말씀하셨습니다. 이와 관련된 동일한 문제를 경험한 다른 수강생들의 질문과 지식공유자님의 답변이 있어서 해당 내용을 공유드리겠습니다.
이 현상은 데이터베이스에서 AUTO_INCREMENT 속성(또는 이와 유사한 기능)을 사용하는 필드(ID 필드 등)에 대해 발생할 수 있습니다. 삽입, 삭제, 갱신과 같은 데이터베이스 작업 과정에서 내부 ID 할당 메커니즘이 건너뛰어서 번호를 할당하는 경우가 있습니다. 특히, 임시 테이블을 사용하거나, 테스트 과정에서 데이터를 여러 번 삽입, 삭제하면서 시퀀스 번호가 건너뛰게 되는 경우가 있습니다.
해당 문제에 대한 지식공유자님의 답변을 참조하실 수 있는 링크는 다음과 같습니다:
- id값이 갑자기 이상하게 되는 현상
- id 숫자 건너띄는 문제
- database의 id값 생성관련
위 링크들에서는 지식공유자님이 해당 이슈에 대해 자세히 설명하고 일부 해결 방법을 제안하고 있습니다. 대체로, 이런 건너뛰기 현상은 데이터베이스의 정상적인 동작으로 볼 수 있으며, 이전 데이터를 삭제하였더라도 시퀀스는 삭제된 ID를 다시 사용하지 않고 새로운 번호를 할당하기 때문에 발생합니다.
단, 이러한 ID 건너뛰기가 데이터베이스 상의 데이터 무결성이나 애플리케이션의 실행에 영향을 주는 문제는 아니므로, 일반적으로는 큰 문제가 되지 않습니다. 만약, ID 값을 초기화하고자 한다면 sequence 또는 AUTO_INCREMENT 값을 초기화하는 SQL 명령을 사용할 수 있습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
..
0
76
2
Unused property.....
0
102
2
project JDK is misconfigured
0
132
2
외부 API의 ID 타입(String/UUID)과 내부 도메인의 ID 타입(Long)이 불일치할 때의 설계 정석
0
83
2
단위/통합 테스트 버전충돌 문제
0
91
2
❗️springboot 4.0.2 버전 aspectj dependency 설정❗️
0
230
1
왜 컨트롤러는 변한게 없는데 새로 만든 html 파일이 뜨나요?
0
104
2
윈도우 build test오류 질문
1
103
2
테스트 관련 공부에 대한 조언을 얻고 싶습니다
0
101
2
테스트 실행 시 에러 질문
0
292
1
name을 통한 비교와 객체를 통한 비교
0
77
1
빌드 후 libs 없음
1
129
1
윈도우 gradlew.bat 에러
0
168
1
@PostMapping("/members/new")가 동작하지 않습니다
0
90
1
java static class와 kotlin class
0
79
1
스프링 DB연결
0
127
1
소요 시간
0
87
2
ddl.sql에 빨간 밑줄
1
102
2
welcome page 에러
0
183
3
잘 모르겠습니다.
0
164
2
fail을 똑같이 쳤는데 오류가 발생해요
0
157
2
index.html Welcome page
0
125
1
프로젝트 gradle-groovy ?
0
370
1
테스트코드 메서드명 한글
0
202
2





