데이터베이스 모델을 개발하고 설계할 때 관계에 포함된 값이 특정 값과 같은지 쿼리해야 하는 경우가 있습니다. 이 문제는 실제 응용에서 자주 발생하지만 해결하기 쉽지 않을 수 있습니다. 이 기사에서는 관계에 내재된 값이 특정 값과 같은지 여부를 쿼리하는 효율적인 방법이 있는 모델을 소개하겠습니다. 걱정하지 마세요. 빠른 이해와 실제 개발에 적용할 수 있도록 간결하고 이해하기 쉬운 언어로 명료하게 설명해 드리겠습니다. 한 번 보자!
질문 내용
두 가지 모델이 있습니다. (cars
和 types
),它们彼此相关(属于关系),其中两个模型都有一个嵌入式 struct
用于公共数据(post
)。我想检索某些 types
,但只想收到 post
的 cars
특정 값과 동일한 값으로 답변합니다.
shorty는 아래 모델을 기반으로 모든 types
,其中cars.post.published
이 참인 것을 찾고 싶다고 말했습니다.
모델
으아악를 사용하면 db.preload("car").find(&type)
我能够在答案对象中获取 car
值。如果我在 car
结构上使用 where()
函数(即 where(car{brand: "volvo"}
) 我可以通过 brand
获取值,但是当使用 post
时(即 where(car{post: post {published: true})
) 모든 내용이 반환됩니다.
쿼리해야 할 기본 모델을 where()
함수 기반으로 사용하는 것이 더 좋을 것 같습니다. 예:
...하지만 그건 안되는 것 같아요. 원시 SQL 생성기를 사용하지 않고 이러한 쿼리를 구현하는 방법은 무엇입니까?
Solution
다음과 같은 방법으로 문제를 해결할 수 있었습니다. 먼저 코드를 공유한 다음 설명할 가치가 있는 핵심 사항을 다루겠습니다.
으아악이제 몇 가지 통찰력을 공유하겠습니다.
구조 정의
이 장면을 처리하기 위해 약간 변경했습니다. type
结构中删除了 car
字段,并在 car
구조 정의에서 해당 항목을 추가했습니다.
설정 및 씨앗
그런 다음 gorm을 통해 데이터베이스 연결을 설정했습니다. 코드에 정의된 모델을 데이터베이스에 존재하는 관계와 동기화합니다. 시연하기 위해 일부 더미 데이터를 수동으로 시드했습니다.
논리 읽기
그런 다음 쿼리를 실행하여 관련 데이터를 가져옵니다. 저는 다음 방법을 사용했습니다:
-
debug
: 실제 SQL 문을 기록하는 데 사용됩니다 -
model
: 처리하려는 관계를 지정하는 데 사용됩니다 -
preload
:用于加载type
관련 -
where
: 조건을 지정하는 데 사용됩니다(이 경우 필터는 내장된 구조에 있습니다) -
find
: 결과를 변수에 매핑하는 데 사용
이것이 문제 해결에 도움이 되었는지 알려주세요. 감사합니다!
위 내용은 관계에 포함된 값이 특정 값과 동일한 모델을 쿼리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

GO의 핵심 기능에는 쓰레기 수집, 정적 연결 및 동시성 지원이 포함됩니다. 1. Go Language의 동시성 모델은 고루틴 및 채널을 통한 효율적인 동시 프로그래밍을 실현합니다. 2. 인터페이스 및 다형성은 인터페이스 방법을 통해 구현되므로 서로 다른 유형을 통일 된 방식으로 처리 할 수 있습니다. 3. 기본 사용법은 기능 정의 및 호출의 효율성을 보여줍니다. 4. 고급 사용에서 슬라이스는 동적 크기 조정의 강력한 기능을 제공합니다. 5. 레이스 조건과 같은 일반적인 오류는 Getest-race를 통해 감지 및 해결할 수 있습니다. 6. 성능 최적화는 sync.pool을 통해 개체를 재사용하여 쓰레기 수집 압력을 줄입니다.

Go Language는 효율적이고 확장 가능한 시스템을 구축하는 데 잘 작동합니다. 장점은 다음과 같습니다. 1. 고성능 : 기계 코드로 컴파일, 빠른 달리기 속도; 2. 동시 프로그래밍 : 고어 라틴 및 채널을 통한 멀티 태스킹 단순화; 3. 단순성 : 간결한 구문, 학습 및 유지 보수 비용 절감; 4. 크로스 플랫폼 : 크로스 플랫폼 컴파일, 쉬운 배포를 지원합니다.

SQL 쿼리 결과의 정렬에 대해 혼란스러워합니다. SQL을 학습하는 과정에서 종종 혼란스러운 문제가 발생합니다. 최근 저자는 "Mick-SQL 기본 사항"을 읽고 있습니다.

기술 스택 컨버전스와 기술 선택의 관계, 소프트웨어 개발에서 기술 스택의 선택 및 관리는 매우 중요한 문제입니다. 최근에 일부 독자들은 ...

골란 ...

GO 언어로 세 가지 구조를 비교하고 처리하는 방법. GO 프로그래밍에서는 때때로 두 구조의 차이점을 비교하고 이러한 차이점을 ...에 적용해야합니다.

GO에서 전 세계적으로 설치된 패키지를 보는 방법? Go Language로 발전하는 과정에서 Go는 종종 사용합니다 ...

골란드의 사용자 정의 구조 레이블이 표시되지 않으면 어떻게해야합니까? Go Language 개발을 위해 Goland를 사용할 때 많은 개발자가 사용자 정의 구조 태그를 만날 것입니다 ...


핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

드림위버 CS6
시각적 웹 개발 도구

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

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

뜨거운 주제



