강의

멘토링

커뮤니티

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

coldbrew님의 프로필 이미지
coldbrew

작성한 질문수

Slack 클론 코딩[백엔드 with NestJS + TypeORM]

회원가입 만들기

camel & snake case 질문드립니다!

작성

·

960

0

일반적(?)으로,
코드상에서 존재하는 변수들이나 코드들은
카멜케이스로 작성,

외부 요청 (API 통신)을 때에는
snake case 형식으로 통신을 하는 것으로 알고 있습니다.

물론 상관없다라는 이야기가 나올 수 있지만,
협업관계에서는 되도록 일반적인, 익숙한 약속을 서로
맞춰 사용하는 것이 낫고 최대한
사소한 부분이나 스타일 관련해서는
충돌을 피하는 것이 낫다고 생각하기에,
응답할때에는 snake case 로 보내고 싶습니다.

tpyeorm 을 작성하면서 find나,
dto 작성이나,
엔티티 작성때에서 camel case 형식으로
변수가 작성되는 것 같은데,
혹시 이들을 응답할때 snake 로 자동변환해주는
어떤 방법이나,
또는 어떤방식으로 사용하고 계신지 궁금해서 질문드립니다!

답변 1

2

제로초(조현영)님의 프로필 이미지
제로초(조현영)
지식공유자

typeorm 부분까지는 자바스크립트라서 camelCase가 일반적입니다.

실제 DB 쿼리는 snake_case를 쓰는데요. 저희 회사 코드를 보여드리자면 다음과 같이 snake case를 넣는 자리가 있습니다.

@Entity('TB_GOODS', { schema: 'ohpick1' })
export class TbGoods {
@ApiProperty({
example: 1,
description: '상품키',
})
@PrimaryGeneratedColumn({ type: 'int', name: 'GOODS_KEY', comment: '시퀀스' })
goodsKey: number;
  @ManyToOne(() => TbMall, (tbMall) => tbMall.goods, {
onDelete: 'RESTRICT',
onUpdate: 'RESTRICT',
})
@JoinColumn([{ name: 'MALL_KEY', referencedColumnName: 'mallKey' }])
mallKey: number;
coldbrew님의 프로필 이미지
coldbrew

작성한 질문수

질문하기