db 컬럼 이름 형식
480
작성한 질문수 1
JPA 관련 질문 드립니다.
db 테이블의 컬럼 이름을 만들 때 isSold 라는 컬럼을 케멀케이스 형식으로 만들었습니다.

그런데 이러한 함수를 만들어서 사용할려고 하니 계속 에러가 떴습니다.
이러한 에러가 나와서 살펴보니 is_sold라는 컬럼을 찾는 것 같은데 저는 IsSold라고 컬럼명을 지어서 오류가 나는 거라고 생각이듭니다.
제가 궁금한점은
1. jpa가 스네이크케이스 형식으로 컬럼명을 자동으로 찾는 것 같아 오류가 나오는 걸로 생각이 드는데 이게 맞을까요?
2. 그럼 db의 컬럼 명을 처음 만들 때 컬럼명이 길 경우 스네이크케이스 형식으로 만들어야 할까요? 보편적으로 어떻게 하는지 궁금합니다.
답변 2
0
안녕하세요 동현님! 🙂 질문 주셔서 감사합니다.
인프런 AI 인턴이 언급해준것처럼, 기본적으로 JPA는 camelCase로 되어 있는 변수 이름을 snake_case로 매핑하게 됩니다. 이런 옵션은 JPA Naming 전략 변경을 통해 바꿀 수 있어요!
다만, 일반적으로 DB의 필드는 snake_case를 사용하는 것이 관례이기 때문에 보통은 기본 옵션을 사용하는 편입니다!
이제 질문 주신 내용에 답변을 드려 보면,
[1. jpa가 스네이크케이스 형식으로 컬럼명을 자동으로 찾는 것 같아 오류가 나오는 걸로 생각이 드는데 이게 맞을까요?]
네 맞습니다! 기본적으로 snake_case 형식을 찾게 됩니다.
[2. 그럼 db의 컬럼 명을 처음 만들 때 컬럼명이 길 경우 스네이크케이스 형식으로 만들어야 할까요? 보편적으로 어떻게 하는지 궁금합니다.]
네 맞습니다! 보편적으로 snake_case를 사용합니다! (잘 보시면 강의에서 함께 만들어 보았던 warehousing_date도 snake_case로 되어 있습니다! 🙂)
또 궁금한 점 생기시면 언제든 편하게 질문 주세요!
감사합니다! 🙏
0
안녕하세요, 인프런 AI 인턴입니다.
김동현님, JPA와 관련한 질문에 대해 상세하게 설명 드리겠습니다.
질문하신 내용에 따르면, 예상하신 바와 같이 JPA는 CamelCase로 작성된 필드명을 데이터베이스 컬럼명과 매핑할 때 SnakeCase로 변환하여 찾습니다. 예를 들어, Java 엔티티에서
isSold라는 필드명을 사용할 경우 데이터베이스에서는is_sold로 매핑하려고 시도합니다. 이는 JPA 구현체인 Hibernate의 기본 동작 방식입니다.데이터베이스 컬럼명을 작명할 때는 SnakeCase 형식을 사용하는 것이 일반적인 관례입니다. 특히, JPA를 사용할 경우 컬럼명이 긴 경우에도 SnakeCase 형식을 사용하여 컬럼명을 지정하는 것이 좋습니다. 이는 JPA와 데이터베이스 간의 매핑에서 발생할 수 있는 혼란과 에러를 방지할 수 있습니다.
언급하신 문제와 관련하여, 이전에 동일하거나 유사한 주제에 대해 답변된 게시물이 있습니다. 아래 링크들에서 해당 주제에 대한 더 자세한 해설을 찾아보실 수 있습니다.
-
- 이 게시글에서는 JPA를 사용할 때 Entity 객체 내의 camelCase 변수 이름이 데이터베이스의 snake_case 형태로 자동으로 변환되어 쿼리문이 실행되는지에 대해 질문하고 있으며, 이에 대한 답변을 제공하고 있습니다.
- 이 게시글에서는 JPA를 사용할 때 Entity 객체 내의 camelCase 변수 이름이 데이터베이스의 snake_case 형태로 자동으로 변환되어 쿼리문이 실행되는지에 대해 질문하고 있으며, 이에 대한 답변을 제공하고 있습니다.
-
- SQL 오류 메시지에서 특정 컬럼을 찾을 수 없다는 문제에 대한 특정 상황을 다루고 있으며, 컬럼 네이밍과 관련된 문제를 설명하고 있습니다.
- SQL 오류 메시지에서 특정 컬럼을 찾을 수 없다는 문제에 대한 특정 상황을 다루고 있으며, 컬럼 네이밍과 관련된 문제를 설명하고 있습니다.
이 자료들을 통해 JPA에서 엔티티 필드 이름과 데이터베이스 컬럼 이름 간의 규칙 및 관례를 보다 명확히 이해할 수 있습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
패키지 구분에 대해 궁금한게 있습니다
0
25
2
리액트 관련 질문이 있습니다.
0
64
2
스프링부트 버전
0
76
2
7강 강의를 들으려고 했는데 오류가 나서 서버가 안 켜지는거 같아요.
0
59
2
33강. UserLoanHistory의 관계성에 대한 질문
1
56
2
Java JDK 버전 문의의 건
0
135
2
ec2 에서 Linux버전이 달라져서 설치가 안되는것 같은데 자료 최신화좀 해주세요.
0
90
3
h2 console 접속했을 테이블 질문
1
66
1
ec2 서버에서 스프링 실행도 되고 인바운드 설정까지 했는데 index.html 안됨
0
79
2
15강. updateUser() 질문
0
56
2
깃허브 질
0
84
2
여기까지 다 끝냈다고 하셨는데
0
79
2
왜안될까요
0
72
2
MySQL 창이안ㄴ뜹니다
0
59
2
포스트맨
0
52
1
spring 개념적인 질문
0
71
2
인텔리제이 샘플코드 실행 안됨 오류
0
141
2
aws 배포할때 .env 파일에 저장한 환경변수에 관하여 여쭤볼게 있습니다
0
86
1
마이그레이션 오류입니다.
0
175
3
Whitelabel Error Page 오류가 났습니다.
0
166
2
안녕하십니까! 오류가 났습니다.. 도와주세요 ㅜㅜ
1
94
3
궁금한게 있습니다.
0
60
2
DTO 관련
0
70
2
궁금한게 있습니다!
0
69
2





