인프런 커뮤니티 질문&답변

김동현님의 프로필 이미지

작성한 질문수

자바와 스프링 부트로 생애 최초 서버 만들기, 누구나 쉽게 개발부터 배포까지! [서버 개발 올인원 패키지]

db 컬럼 이름 형식

24.05.17 01:22 작성

·

190

·

수정됨

0

JPA 관련 질문 드립니다.

db 테이블의 컬럼 이름을 만들 때 isSold 라는 컬럼을 케멀케이스 형식으로 만들었습니다.

그런데 이러한 함수를 만들어서 사용할려고 하니 계속 에러가 떴습니다.
이러한 에러가 나와서 살펴보니 is_sold라는 컬럼을 찾는 것 같은데 저는 IsSold라고 컬럼명을 지어서 오류가 나는 거라고 생각이듭니다.

제가 궁금한점은
1. jpa가 스네이크케이스 형식으로 컬럼명을 자동으로 찾는 것 같아 오류가 나오는 걸로 생각이 드는데 이게 맞을까요?
2. 그럼 db의 컬럼 명을 처음 만들 때 컬럼명이 길 경우 스네이크케이스 형식으로 만들어야 할까요? 보편적으로 어떻게 하는지 궁금합니다.

답변 2

0

최태현님의 프로필 이미지
최태현
지식공유자

2024. 05. 17. 14:09

안녕하세요 동현님! 🙂 질문 주셔서 감사합니다.

인프런 AI 인턴이 언급해준것처럼, 기본적으로 JPA는 camelCase로 되어 있는 변수 이름을 snake_case로 매핑하게 됩니다. 이런 옵션은 JPA Naming 전략 변경을 통해 바꿀 수 있어요!

image다만, 일반적으로 DB의 필드는 snake_case를 사용하는 것이 관례이기 때문에 보통은 기본 옵션을 사용하는 편입니다!

 

이제 질문 주신 내용에 답변을 드려 보면,

[1. jpa가 스네이크케이스 형식으로 컬럼명을 자동으로 찾는 것 같아 오류가 나오는 걸로 생각이 드는데 이게 맞을까요?]

네 맞습니다! 기본적으로 snake_case 형식을 찾게 됩니다.


[2. 그럼 db의 컬럼 명을 처음 만들 때 컬럼명이 길 경우 스네이크케이스 형식으로 만들어야 할까요? 보편적으로 어떻게 하는지 궁금합니다.]

네 맞습니다! 보편적으로 snake_case를 사용합니다! (잘 보시면 강의에서 함께 만들어 보았던 warehousing_date도 snake_case로 되어 있습니다! 🙂)

 

또 궁금한 점 생기시면 언제든 편하게 질문 주세요!

감사합니다! 🙏

0

인프런 AI 인턴님의 프로필 이미지

2024. 05. 17. 01:26

안녕하세요, 인프런 AI 인턴입니다.

김동현님, JPA와 관련한 질문에 대해 상세하게 설명 드리겠습니다.

  1. 질문하신 내용에 따르면, 예상하신 바와 같이 JPA는 CamelCase로 작성된 필드명을 데이터베이스 컬럼명과 매핑할 때 SnakeCase로 변환하여 찾습니다. 예를 들어, Java 엔티티에서 isSold라는 필드명을 사용할 경우 데이터베이스에서는 is_sold로 매핑하려고 시도합니다. 이는 JPA 구현체인 Hibernate의 기본 동작 방식입니다.

  2. 데이터베이스 컬럼명을 작명할 때는 SnakeCase 형식을 사용하는 것이 일반적인 관례입니다. 특히, JPA를 사용할 경우 컬럼명이 긴 경우에도 SnakeCase 형식을 사용하여 컬럼명을 지정하는 것이 좋습니다. 이는 JPA와 데이터베이스 간의 매핑에서 발생할 수 있는 혼란과 에러를 방지할 수 있습니다.

언급하신 문제와 관련하여, 이전에 동일하거나 유사한 주제에 대해 답변된 게시물이 있습니다. 아래 링크들에서 해당 주제에 대한 더 자세한 해설을 찾아보실 수 있습니다.

  • @column 어노테이션 관련하여 질문드립니다.

    • 이 게시글에서는 JPA를 사용할 때 Entity 객체 내의 camelCase 변수 이름이 데이터베이스의 snake_case 형태로 자동으로 변환되어 쿼리문이 실행되는지에 대해 질문하고 있으며, 이에 대한 답변을 제공하고 있습니다.
  • 31강 질문

    • SQL 오류 메시지에서 특정 컬럼을 찾을 수 없다는 문제에 대한 특정 상황을 다루고 있으며, 컬럼 네이밍과 관련된 문제를 설명하고 있습니다.

이 자료들을 통해 JPA에서 엔티티 필드 이름과 데이터베이스 컬럼 이름 간의 규칙 및 관례를 보다 명확히 이해할 수 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.

현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏

추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.