Rumah > Artikel > hujung hadapan web > Bagaimana untuk Mengisih Susunan Skor Terbenam dalam MongoDB?
Isih Susunan dalam Rekod Koleksi dalam MongoDB
Pernyataan Masalah
Pertimbangkan koleksi rekod pelajar dalam MongoDB, di mana setiap rekod termasuk tatasusunan skor terbenam. Tugasnya adalah untuk mengisih tatasusunan skor dalam susunan menurun berdasarkan nilai skor.
Penyelesaian
Disebabkan pengehadan bahasa pertanyaan MongoDB, memanipulasi tatasusunan terbenam secara langsung dalam pertanyaan itu sendiri tidak mungkin. Untuk mencapai pengisihan ini, anda boleh meneroka dua pendekatan:
1. Isih Tahap Aplikasi
Ekstrak tatasusunan skor daripada koleksi menggunakan pertanyaan cari. Isih tatasusunan skor dalam susunan menurun dalam kod aplikasi anda. Kemas kini rekod dengan tatasusunan skor yang diisih kembali ke MongoDB.
2. Rangka Kerja Pengagregatan MongoDB
Menggunakan Rangka Kerja Pengagregatan MongoDB, anda boleh melakukan pengisihan dalam MongoDB itu sendiri. Berikut ialah saluran paip pengagregatan sampel yang mengisih markah kerja rumah dalam tertib menurun:
db.students.aggregate([ { $match: { _id: 1 } }, // Initial document match { $unwind: '$scores' }, // Expand scores array into individual documents { $match: { 'scores.type': 'homework' } }, // Filter to homework scores { $sort: { 'scores.score': -1 } }, // Sort in descending order ])
Sampel Output:
{ "result" : [ { "_id" : 1, "name" : "Aurelia Menendez", "scores" : { "type" : "homework", "score" : 71.76133439165544 } }, { "_id" : 1, "name" : "Aurelia Menendez", "scores" : { "type" : "homework", "score" : 34.85718117893772 } } ], "ok" : 1 }
Atas ialah kandungan terperinci Bagaimana untuk Mengisih Susunan Skor Terbenam dalam MongoDB?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!