sql >> Databasteknik >  >> NoSQL >> MongoDB

Hur upprätthålls ordningen på fastigheter för sortering i mongodb?

Detta är en intressant fråga.

Det fungerar som de flesta ECMAScript-implementationer faktiskt gör bevara nyckelordningen (t.ex. V8 som används av Node). Den officiella Node MongoDB-drivrutinen uppmuntrar inte dess användning, istället erbjuder den två olika notationer:

Mongoose-dokumentationen nämner ingenting om nyckelordning (åtminstone inte vad jag känner till). Men den erbjuder också två olika metoder för sortering :

Det verkar faktiskt som att sorteringsfunktionen i Mongoose var baserad på felaktiga (men för närvarande giltiga) antaganden. Det är förmodligen bäst om du använder strängnotationen när du sorterar med flera nycklar.Sortering med objektnotationen fungerar korrekt när du använder MongoDB direkt (t.ex. i MongoDB-skalet) eftersom den inte använder ren JSON utan förlängd JSON .

Se även denna mycket relaterade fråga:Hur kan du ange ordningen på egenskaper i ett javascript-objekt för ett MongoDB-index i node.js?

Det finns också ett Mongosproblem om detta:

Så när du använder Mongoose, använd antingen strängnotationen eller det nyligen tillagda stödet för ES2015 Maps som garanterat kommer att beställas genom insättningsorder.



  1. Vilka är konsekvenserna av att inaktivera skvaller, mingel och hjärtslag för selleriarbetare?

  2. Hur kommer man runt detta MongoDB/Node asynkrona problem?

  3. Hur aggregerar man och slår samman resultatet till en samling?

  4. Spela 2.0 och MongoDB i gränssnitt med Salat