관계에 포함된 값이 특정 값과 동일한 모델을 쿼리하는 방법은 무엇입니까?

WBOY
풀어 주다: 2024-02-09 18:39:08
앞으로
916명이 탐색했습니다.

관계에 포함된 값이 특정 값과 동일한 모델을 쿼리하는 방법은 무엇입니까?

데이터베이스 모델을 개발하고 설계할 때 관계에 포함된 값이 특정 값과 같은지 쿼리해야 하는 경우가 있습니다. 이 문제는 실제 응용에서 자주 발생하지만 해결하기 쉽지 않을 수 있습니다. 이 기사에서는 관계에 내재된 값이 특정 값과 같은지 여부를 쿼리하는 효율적인 방법이 있는 모델을 소개하겠습니다. 걱정하지 마세요. 빠른 이해와 실제 개발에 적용할 수 있도록 간결하고 이해하기 쉬운 언어로 명료하게 설명해 드리겠습니다. 한 번 보자!

질문 내용

두 가지 모델이 있습니다. (carstypes),它们彼此相关(属于关系),其中两个模型都有一个嵌入式 struct 用于公共数据(post)。我想检索某些 types,但只想收到 postcars 특정 값과 동일한 값으로 답변합니다.

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을 통해 데이터베이스 연결을 설정했습니다. 코드에 정의된 모델을 데이터베이스에 존재하는 관계와 동기화합니다. 시연하기 위해 일부 더미 데이터를 수동으로 시드했습니다.

논리 읽기

그런 다음 쿼리를 실행하여 관련 데이터를 가져옵니다. 저는 다음 방법을 사용했습니다:

  1. debug: 실제 SQL 문을 기록하는 데 사용됩니다
  2. model: 처리하려는 관계를 지정하는 데 사용됩니다
  3. preload:用于加载type관련
  4. where: 조건을 지정하는 데 사용됩니다(이 경우 필터는 내장된 구조에 있습니다)
  5. find: 결과를 변수에 매핑하는 데 사용

이것이 문제 해결에 도움이 되었는지 알려주세요. 감사합니다!

위 내용은 관계에 포함된 값이 특정 값과 동일한 모델을 쿼리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:stackoverflow.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!