작성
·
235
·
수정됨
0
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에서 엔티티 필드 이름과 데이터베이스 컬럼 이름 간의 규칙 및 관례를 보다 명확히 이해할 수 있습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.