Rumah >pembangunan bahagian belakang >Golang >Bagaimana untuk Membina Operator Logik Bersarang dalam Pertanyaan MongoDB dengan Pemacu Go?

Bagaimana untuk Membina Operator Logik Bersarang dalam Pertanyaan MongoDB dengan Pemacu Go?

Patricia Arquette
Patricia Arquetteasal
2024-11-19 01:17:02810semak imbas

How to Construct Nested Logical Operators in MongoDB Queries with Go Driver?

Menyiasat MongoDB dengan Operator Logikal Bersarang

Apabila menulis pertanyaan MongoDB yang kompleks, ia menjadi perlu untuk menggunakan pengendali logik bersarang seperti ATAU dalam DAN atau sebaliknya. Walau bagaimanapun, pemacu MongoDB rasmi untuk Go memberikan cabaran apabila membina pertanyaan sedemikian.

Isu timbul apabila cuba mencipta penapis pertanyaan berlapis menggunakan bson.D, yang menjangkakan elemen bson.E. Untuk mencapai logik OR/AND bersarang, seseorang mungkin cuba menyarang bson.M dalam bson.D, seperti yang dilihat dalam contoh berikut:

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

Walau bagaimanapun, pendekatan ini menghasilkan ralat: "tidak boleh menggunakan primitif .M literal (type primitive.M) as type primitive.E in slice literal."

Pendekatan yang betul melibatkan penggunaan tatasusunan (bson.A) untuk $or dan mengetepikan operator $and yang jelas (yang tersirat secara lalai). Berikut ialah tiga pilihan yang sah untuk mencipta penapis bersarang:

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

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

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

Penapis ini akan mewakili ungkapan logik bersarang dengan betul dan boleh digunakan untuk mendapatkan semula data daripada koleksi MongoDB.

Atas ialah kandungan terperinci Bagaimana untuk Membina Operator Logik Bersarang dalam Pertanyaan MongoDB dengan Pemacu Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn