inflearn logo
강의

Course

Instructor

Spring DB Part 1 - Core Principles of Data Access

JDBC Development - Query

memberId 맴버변수를 String 으로 잡은 이유

127

jason

74 asked

0

도메인의 Member 클래스 의 memberId 맴벼변수 타입이 String인 이유가 궁금합니다 jbdc에 대표 id 등록은 숫자형 타입이 아닌 문자형으로 해야 하는지 궁금합니다

spring mvc spring-jdbc

Answer 2

0

y2gcoder

안녕하세요. 홍태경님, 공식 서포터즈 y2gcoder입니다.

여기서의 memberId는 database 의 기본키가 아니라 서비스 가입 시 간혹 입력하거나 부여받는 ID로 생각하시면 좋을 것 같습니다 🙂

감사합니다.

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다. 홍태경님.

Member 클래스의 memberId를 String 타입으로 선언한 이유는 여러 여건이나 설계 요구에 따라 다를 수 있는데, 아래와 같은 이유가 일반적으로 고려될 수 있습니다:

  1. 유연성: 때로는 숫자 형태의 ID보다는 다양한 문자나 형식(예: 알파벳과 숫자의 조합)의 ID가 필요할 수 있습니다. 이러한 경우, String 타입이 더 유연한 선택이 될 수 있습니다.

  2. 특수 요구 사항: 특정 비즈니스 로직이나 데이터베이스 설계에 따라 ID가 문자형식이어야 할 가능성도 있습니다. 예를 들어, 특정 로깅 시스템이나 외부 시스템과의 연동에서 이러한 형식이 필요할 수 있습니다.

  3. 식별값의 안정성: 숫자로만 이루어진 ID보다는 문자와 숫자가 혼합된 ID가 더 충돌이 적고, 잘못된 데이터 처리를 예방할 수 있는 경우도 있습니다.

JDBC에서는 데이터베이스 컬럼의 타입에 따라, 숫자를 저장할 때는 integer, bigInt 등을 사용하고 문자는 varchar, char 등을 사용하게 됩니다. 따라서, JDBC 입장에서 memberId가 숫자로 저장되어야 한다면, Member 클래스의 해당 필드형을 String 대신 Long이나 Integer로 정의하는 것이 일반적입니다.

아래 링크에서 유사한 질문과 답변을 참조하실 수 있습니다:
- memberId
- Member.id 타입이 long이 아닌 Long인이유

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

spring initialiser 어떤걸 선택해야될지 모르겠어요

0

27

2

트랜잭션 템플릿이 체크예외는 커밋하는 이유가 궁금합니다.

0

49

1

jdbc 학습하다 궁금해서 질문드려요

0

80

1

정상이체와 이체중 예외발생 차이

0

68

2

이번 강의부터가 JDBC 직접 사용 맞나요?

0

86

1

순수한 서비스 계층에 대한 의문???

0

82

2

3_4test, 4test 자동 리소스 안됨

0

58

2

데이터베이스 선택 관련 질문.

0

68

2

after 메서드 사용 유무

0

56

2

데이터베이스 접근 및 DB 락

0

52

1

@SpingBootTest, @TestConfiguration

0

55

1

Read Committed 격리 수준 사용 관련 질문

0

48

1

AopCheck Test 부분의 EnhancerBySpring 확인 법??

0

66

2

커리큘럼 관련 질문

0

76

1

서비서 계층 스프링 프레임워크 사용

0

87

1

validation(toMember)의 위치

0

83

2

데이터 계층에서 서비스 로직의 datasource를 인식하는 방법

0

165

2

member 상수 질문

0

120

2

ctrl + F6 이후로 con 인식이 안 됩니다

0

153

2

DrivenManager 와 Connection 반환에 대한 질문입니다!

0

108

1

섹션5 트랜잭션 템플릿관련 질문(이기종 DB)

0

116

1

세션1 테이블 조회결과 그림은 Redo 로그에 속하나요?

0

94

1

트랜잭션이 필요하지 않은 경우 DB 대신 파일 시스템을 사용하는 것이 더 효율적인가?

0

95

1

강의 14분쯤 Exception 질문

0

111

2