MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

model mangusty, tablica ciągów, tablica struktury obiektów

Ulubione muszą być tablicą String w następujący sposób:favorites: [String]

W przypadku tablicy koszyka mamy dwie główne opcje:

  1. Możemy zdefiniować koszyk jako tablicę subdocuments .
const schema = new Schema({
  email: { type: String, unique: true, required: true },
  hash: { type: String, required: true },
  createdDate: { type: Date, default: Date.now },
  settings: {
    favorites: [String],
    cart: [
      {
        quantity: Number,
        marketId: String
      }
    ],
    states: {
      favorites: { type: Boolean, default: true },
      search: { type: Boolean, default: false },
      category: { type: Schema.Types.Mixed, default: false }
    }
  }
});
  1. Lub możemy zadeklarować koszyk jako tablicę schema types .
const schema = new Schema({
  email: { type: String, unique: true, required: true },
  hash: { type: String, required: true },
  createdDate: { type: Date, default: Date.now },
  settings: {
    favorites: [String],
    cart: [
      new Schema({
        quantity: Number,
        marketId: String
      })
    ],
    states: {
      favorites: { type: Boolean, default: true },
      search: { type: Boolean, default: false },
      category: { type: Schema.Types.Mixed, default: false }
    }
  }
});

Dla obu z nich, kiedy tworzysz dokument, będzie on wyglądał tak, zauważ, że mangusta dodała pole _id w elementach karty.

{
    "settings": {
        "states": {
            "favorites": true,
            "search": false,
            "category": false
        },
        "favorites": [
            "234",
            "564",
            "213",
            "782"
        ],
        "cart": [
            {
                "_id": "5e6cd0bd53feb32d50699b79",
                "quantity": 5,
                "marketId": "234"
            },
            {
                "_id": "5e6cd0bd53feb32d50699b78",
                "quantity": 2,
                "marketId": "564"
            },
            {
                "_id": "5e6cd0bd53feb32d50699b77",
                "quantity": 7,
                "marketId": "213"
            },
            {
                "_id": "5e6cd0bd53feb32d50699b76",
                "quantity": 3,
                "marketId": "782"
            }
        ]
    },
    "_id": "5e6cd0bd53feb32d50699b75",
    "email": "[email protected]",
    "hash": "hash...",
    "createdDate": "2020-03-14T12:40:29.969Z",
    "__v": 0,
    "id": "5e6cd0bd53feb32d50699b75"
}

Jeśli nie chcesz _id pola w tablicy koszyka, możesz dodać _id: false wybierz schemat koszyka w następujący sposób:

    cart: [
      new Schema(
        {
          quantity: Number,
          marketId: String
        },
        { _id: false }
      )
    ],

Oto kilka przydatnych dokumentów:

Tablice

Dokumenty podrzędne




  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. MongoDB:znajdź czas wykonania polecenia count() na milionach rekordów w kolekcji?

  2. MongoDB działa, ale nie można się połączyć za pomocą powłoki

  3. Mongodb zapisuje listę obiektów

  4. Spring HATEOAS RepresentationModel, nie można ustawić łączy właściwości, ponieważ nie ma setera, nie więdnie i nie jest częścią konstruktora trwałości

  5. Pobierz tylko żądany element z tablicy obiektów w kolekcji MongoDB