>백엔드 개발 >Golang >Mongo-Go-Driver에서 중첩된 OR/AND 쿼리 필터를 만드는 방법은 무엇입니까?

Mongo-Go-Driver에서 중첩된 OR/AND 쿼리 필터를 만드는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-18 02:16:02765검색

How to create nested OR/AND query filters in Mongo-Go-Driver?

Mongo-Go-Driver의 중첩된 OR/AND 쿼리 필터

Go 드라이버를 사용하여 MongoDB에서 복잡한 쿼리 필터를 생성할 때 일반적으로 발생하는 문제 OR 및 AND와 같은 중첩 연산자가 필요합니다. 그러나 공식 드라이버에서는 필터를 구축하기 위해 bson.D 및 bson.E 요소를 사용해야 합니다.

중첩된 OR/AND 연산을 처리하려면 bson.D 및 bson.M 개체를 결합할 수 있습니다.

중첩된 OR 조건을 사용하여 AND 필터를 생성하려는 다음 예를 고려하세요.

filter := bson.M{"$and": bson.D{
    {"p", 10},
    {"$or": bson.D{
        {"s", 30},
        {"a", 1}
    }}
}}

이 접근 방식을 사용하면 다음 오류가 발생합니다. .M)을 슬라이스 리터럴의 원시.E 유형으로 사용합니다."

이 문제를 해결하려면 다음과 같이 필터를 정의할 수 있습니다.

filter := bson.D{
    {"p", 10},
    {"$or", bson.A{
        bson.D{{"s", 30}},
        bson.D{{"a", 10}},
    }},
}

여기에서 bson.D를 사용하는 대신 중첩된 OR 조건에 bson.D를 사용하려면 bson.A(bson.D 요소 배열)를 사용합니다. 이는 $or가 필터 배열을 기대하기 때문입니다.

또 다른 옵션은 기본 AND 필터와 중첩 OR 조건 모두에 bson.M을 사용하는 것입니다.

filter = bson.M{
    "p": 10,
    "$or": bson.A{
        bson.M{"s": 30},
        bson.M{"a": 10},
    },
}

이 경우, bson.A는 bson.M 요소도 허용하므로 bson.D 대신 bson.M을 사용하여 중첩된 OR 조건을 정의할 수 있습니다.

위 내용은 Mongo-Go-Driver에서 중첩된 OR/AND 쿼리 필터를 만드는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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