데이터베이스 모델을 개발하고 설계할 때 관계에 포함된 값이 특정 값과 같은지 쿼리해야 하는 경우가 있습니다. 이 문제는 실제 응용에서 자주 발생하지만 해결하기 쉽지 않을 수 있습니다. 이 기사에서는 관계에 내재된 값이 특정 값과 같은지 여부를 쿼리하는 효율적인 방법이 있는 모델을 소개하겠습니다. 걱정하지 마세요. 빠른 이해와 실제 개발에 적용할 수 있도록 간결하고 이해하기 쉬운 언어로 명료하게 설명해 드리겠습니다. 한 번 보자!
두 가지 모델이 있습니다. (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 생성기를 사용하지 않고 이러한 쿼리를 구현하는 방법은 무엇입니까?
다음과 같은 방법으로 문제를 해결할 수 있었습니다. 먼저 코드를 공유한 다음 설명할 가치가 있는 핵심 사항을 다루겠습니다.
으아악이제 몇 가지 통찰력을 공유하겠습니다.
이 장면을 처리하기 위해 약간 변경했습니다. type
结构中删除了 car
字段,并在 car
구조 정의에서 해당 항목을 추가했습니다.
그런 다음 gorm을 통해 데이터베이스 연결을 설정했습니다. 코드에 정의된 모델을 데이터베이스에 존재하는 관계와 동기화합니다. 시연하기 위해 일부 더미 데이터를 수동으로 시드했습니다.
그런 다음 쿼리를 실행하여 관련 데이터를 가져옵니다. 저는 다음 방법을 사용했습니다:
debug
: 실제 SQL 문을 기록하는 데 사용됩니다model
: 처리하려는 관계를 지정하는 데 사용됩니다preload
:用于加载type
관련where
: 조건을 지정하는 데 사용됩니다(이 경우 필터는 내장된 구조에 있습니다) find
: 결과를 변수에 매핑하는 데 사용이것이 문제 해결에 도움이 되었는지 알려주세요. 감사합니다!
위 내용은 관계에 포함된 값이 특정 값과 동일한 모델을 쿼리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!