목차
질문 내용
해결 방법
백엔드 개발 Golang Postgres 및 MongoDB를 사용한 CRUD?

Postgres 및 MongoDB를 사용한 CRUD?

Feb 09, 2024 pm 02:00 PM
사용자 등록

使用 Postgres 和 MongoDB 进行 CRUD?

php 편집기 Xigua는 이 기사에서 Postgres와 MongoDB를 사용하여 CRUD 작업을 수행하는 방법을 알려줄 것입니다. Postgres는 관계형 데이터베이스인 반면 MongoDB는 문서 데이터베이스입니다. CRUD 작업은 데이터를 생성(Create), 읽기(Read), 업데이트(Update), 삭제(Delete)하는 프로세스를 의미합니다. 서로 다른 두 가지 유형의 데이터베이스를 결합하면 서로 다른 요구 사항을 기반으로 데이터 작업에 가장 적합한 데이터베이스를 선택하여 효율성과 유연성을 향상시킬 수 있습니다. 다음으로 CRUD 작업에서 이 두 데이터베이스의 적용을 살펴보겠습니다!

질문 내용

저는 Go와 백엔드를 처음 접하고 Go 인턴십 프로그램에 참여하고 있습니다. 우리는 psql 데이터베이스에 연결하는 CRUD를 구축했으며 이제 개발에 사용할 mongoDB에 연결하고 프로덕션에 PSQL을 사용하라는 메시지를 받았습니다. 처음부터 mongo에 대한 새 핸들러를 생성해야 합니까, 아니면 동일한 핸들러를 사용하여 어떻게든 사용 중인 데이터베이스 유형을 결정하고 이에 따라 로직을 사용할 수 있습니까? 예를 들어, 사용자 등록 엔드포인트에 대한 핸들러가 있습니다:

으아악

mongo에 대한 삽입, 등록 및 CheckIfEmailExists 기능을 구축했습니다.

func (ctrl *UserController) Register(c *gin.Context) {
    var user models.User
    if err := c.BindJSON(&user); err != nil {
        c.AbortWithStatusJSON(http.StatusUnprocessableEntity, gin.H{
            "error":   true,
            "message": err.Error(),
        })
        return
    }
    err := ctrl.userService.Register(&user)
    if err != nil {
        c.AbortWithStatusJSON(http.StatusUnprocessableEntity, gin.H{
            "error":   true,
            "message": err.Error(),
        })
        return
    }

    c.JSON(http.StatusCreated, gin.H{
        "message": "successfully created an user",
    })
}

func (svc *UserService) Register(user *models.User) error {
    if svc.userRepo.CheckIfEmailExists(user.Email) {
        return errors.New("user already registered")
    }
    hash, err := svc.generatePasswordHash(user.Password)
    if err != nil {
        return errors.New("err can't register user")
    }

    user.Password = hash

    return svc.userRepo.Insert(user)
}

func (repo *UserRepository) CheckIfEmailExists(mail string) bool {
    var user models.User
    err := repo.dbClient.Debug().Model(models.User{}).Where("email = ?", mail).Find(&user).Error
    return errors.Is(err, gorm.ErrRecordNotFound)
}

func (repo *UserRepository) Insert(user *models.User) error {
    err := repo.dbClient.Debug().Model(models.User{}).Create(user).Error
    if err != nil {
        log.Printf("failed to insert user: %v\n", err)
        return err
    }
    return nil
}
로그인 후 복사

해결 방법

UserService를 생성하는 방법에 대한 코드를 제공하지 않았습니다.

이상적으로는 다음과 같은 인터페이스가 있어야 합니다.

으아악

그러면 UserService는 다음과 같이 생성되어야 합니다:

으아악

그리고 두 개의 별도 저장소가 있으며 둘 다 UserRepository 인터페이스를 구현합니다. 즉, 인터페이스와 동일한 이름과 서명(매개변수, 반환 유형)을 가진 메소드가 있어야 합니다.

mongo_user_repository.go

으아악

postgres_user_repository.go

으아악

아래의 (매우 나쁜) 예처럼 사용 사례에 따라 이들 중 하나를 전달할 수 있습니다.

main.go

으아악

위 내용은 Postgres 및 MongoDB를 사용한 CRUD?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

철도 12306 이메일 주소 등록 방법 철도 12306 이메일 주소 등록 방법 Apr 30, 2024 am 11:33 AM

Railway 12306 이메일 주소를 등록하는 단계는 다음과 같습니다. 12306 웹사이트를 방문하여 "등록"을 클릭하고 "이메일 등록"을 선택한 후 이메일, 이름, 휴대폰 및 기타 정보를 입력하고 비밀번호를 설정하세요. 메시지가 나타나면 확인 정보를 위해 이메일 확인 코드와 휴대폰 확인 코드를 입력하고 "등록 완료"를 클릭하세요.

NetEase는 Marvel의 첫 MOBA 게임인 'Marvel Super War'의 중단을 발표했습니다! NetEase는 Marvel의 첫 MOBA 게임인 'Marvel Super War'의 중단을 발표했습니다! Apr 18, 2024 am 10:50 AM

넷이즈의 '마블 슈퍼워'는 2024년 6월 17일 15시를 기해 운영을 종료하고 게임 서버를 종료한다고 밝혔다. 현재 모든 플랫폼의 다운로드 입구가 폐쇄되었으며, 게임 재충전 및 신규 유저 등록도 중단되었습니다. 마블 최초의 MOBA 모바일 게임인 이 게임은 슈퍼히어로의 전투 특성을 실감나게 표현하고, 마블 유니버스의 웅장한 세계관을 복원합니다. 게임에서는 어벤저스, 엑스맨, 판타스틱 4를 비롯한 수많은 슈퍼 히어로, 슈퍼 악당들이 평행 우주에 모여 아이언맨, 캡틴 아메리카, 스파이더맨, 로키, 타노스, 데드풀 웨이트와 경쟁할 수 있습니다. 60명 이상의 마블 클래식 캐릭터가 함께 싸울 수 있습니다!

왜 Bitget Wallet 거래소에 등록할 수 없나요? 왜 Bitget Wallet 거래소에 등록할 수 없나요? Sep 06, 2024 pm 03:34 PM

BitgetWallet 거래소에 등록할 수 없는 이유는 계정 제한, 지원되지 않는 지역, 네트워크 문제, 시스템 유지 관리 및 기술적인 장애 등 다양한 이유가 있습니다. BitgetWallet 거래소에 등록하려면 공식 웹사이트를 방문하여 정보를 입력하고 약관에 동의한 후 등록을 완료하고 신원을 확인하세요.

Gate.io Open Sesame 신규 사용자 등록 및 충전 튜토리얼 Gate.io Open Sesame 신규 사용자 등록 및 충전 튜토리얼 Apr 25, 2024 pm 04:53 PM

Gate.io 계정 등록 및 충전 방법: 1. Gate.io 공식 웹사이트를 방문하여 "등록"을 클릭하세요. 2. 가입방법(이메일 또는 휴대폰)을 선택하고 비밀번호를 설정한 후 약관에 동의합니다. 3. 귀하의 계정에 로그인하고 "충전"을 클릭하세요. 4. 충전할 법정화폐 또는 암호화폐를 선택하고 금액을 입력한 후 충전방법을 선택하세요. 5. 충전 주소를 확보하고 외부 지갑이나 거래소에서 자금을 이체합니다.

Douyin은 왜 두 개의 계정을 가지고 있나요? 휴대폰에 두 개의 TikTok을 설치하는 방법은 무엇입니까? Douyin은 왜 두 개의 계정을 가지고 있나요? 휴대폰에 두 개의 TikTok을 설치하는 방법은 무엇입니까? May 06, 2024 pm 09:28 PM

디지털 시대에 소셜 미디어는 사람들의 삶에 필수적인 부분이 되었습니다. Douyin은 중국에서 가장 인기 있는 단편 동영상 플랫폼 중 하나로 많은 사용자를 확보하고 있습니다. 일부 사용자는 두 개의 계정을 등록하기도 했습니다. 그러면 Douyin은 왜 두 개의 계정을 가지고 있습니까? 이 기사에서는 이 질문에 답하고 휴대폰에 두 개의 Douyin 계정을 설치하는 방법을 설명합니다. 1. Douyin에는 왜 두 개의 계정이 있나요? 기능적 차별화: 일부 사용자는 콘텐츠 유형이나 기능에 따라 계정을 차별화합니다. 예를 들어 한 계정은 일상 생활을 공유하는 데 사용되고 다른 계정은 전문 기술을 보여주는 데 사용됩니다. 2. 개인정보 보호: 일부 사용자는 생활과 업무를 분리한 두 개의 계정을 통해 개인정보를 보호하고 정보 유출을 방지하기를 희망합니다. 3. 상호 작용 요구 사항: 일부 사용자는 상호 작용 요구 사항으로 인해 두 개를 등록할 수 있습니다.

Douyin에서 여러 계정 연결을 닫는 방법은 무엇입니까? 계정연결의 역할은 무엇인가요? Douyin에서 여러 계정 연결을 닫는 방법은 무엇입니까? 계정연결의 역할은 무엇인가요? Apr 20, 2024 pm 05:58 PM

현재 가장 인기 있는 단편 비디오 플랫폼인 Douyin은 수많은 사용자가 등록하고 공유하도록 유도하고 있습니다. 일부 사용자는 다양한 목적으로 여러 Douyin 계정을 등록할 수 있습니다. Douyin을 사용하면 사용자가 여러 계정을 연결하여 쉽게 관리할 수 있습니다. 그러나 때로는 사용자가 계정 연결을 해제해야 할 수도 있습니다. 이 글에서는 "Douyin에서 여러 계정의 연결을 닫는 방법"에 중점을 두고 계정 연결을 닫는 방법과 계정 연결의 역할을 자세히 소개합니다. 1. Douyin에서 여러 계정 연결을 종료하는 방법은 무엇입니까? 1. Douyin 앱을 열고 "나" 개인 홈페이지에 들어갑니다. 2. 오른쪽 상단에 있는 "세 줄" 아이콘을 클릭하여 기능 메뉴를 엽니다. 3. 기능 메뉴에서 "설정" 옵션을 찾아 클릭하여 들어갑니다. 4. 설정 페이지에서 "계정 및 보안" 옵션을 찾아 클릭하여 들어갑니다.

외국 usdt 교환 외국 usdt 교환 Apr 19, 2024 pm 04:01 PM

해외 USDT 거래소는 USDT를 중심으로 해외에 등록되어 운영되는 디지털 화폐 거래 플랫폼입니다. 주요 기능에는 USDT 거래 지원, 글로벌 서비스, 높은 유동성, 다중 통화 지원 및 법정 통화 입출금 채널이 포함됩니다. 해외 USDT 거래소를 선택할 때 보안, 거래 수수료, 통화 지원, 법정화폐 입출금, 고객 서비스 지원을 고려해야 합니다. 잘 알려진 거래소로는 Binance, Huobi, Oyi 및 Coinbase가 있습니다.

Douyin의 불꽃 색상 변경 규칙에 대한 자세한 설명은 무엇입니까? 다양한 스파크 색상이 조건을 충족합니다. Douyin의 불꽃 색상 변경 규칙에 대한 자세한 설명은 무엇입니까? 다양한 스파크 색상이 조건을 충족합니다. May 04, 2024 am 09:31 AM

사용자 상호 작용을 향상하고 사용자 경험을 개선하기 위해 Douyin 플랫폼은 흥미로운 상호 작용 메커니즘인 Spark를 출시했습니다. 사용자는 Douyin에서 일련의 작업을 통해 스파크를 활성화하고 업그레이드할 수 있습니다. 다양한 색상은 다양한 업적과 명예를 나타냅니다. Douyin Spark의 색상 변경 규칙을 이해하면 사용자가 더 잘 참여하고 상호 작용하며 Douyin이 제공하는 사회적 즐거움을 즐기는 데 도움이 됩니다. 1. Douyin의 불꽃 색상 변경 규칙에 대한 자세한 설명은 무엇입니까? 1. 행동은 좋아요, 댓글, 공유 등과 같은 사용자의 상호 작용 행동을 활성화하여 스파크를 활성화할 수 있습니다. 2. 레벨 개선 사용자의 상호 작용 행동이 증가함에 따라 스파크가 점차 업그레이드되고 그에 따라 색상이 변경됩니다. 3. 색상 변경 스파크의 색상 변경은 일반적으로 사용자의 상호 작용 빈도, 상호 작용 품질 및 활동 참여에 대한 열정과 관련이 있습니다. 4. 작업이 완료되었습니다

See all articles