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

Patricia Arquette
Lepaskan: 2024-11-19 01:17:02
asal
731 orang telah melayarinya

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}}}}}
Salin selepas log masuk

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},
    },
}
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan