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!