mongoDB

[Mongoose] virtual field만들어서 populate 사용하기 with options

알로호모라 2021. 12. 6. 19:28
반응형

모델 스키마에 virtual 필드를 생성 

const MenuCategorySchema: Schema<IMenuCategory> = new Schema<IMenuCategory>(
  {
    // MySql 메뉴 카테고리 IDX
    idx: { type: Number, required: true, unique: true },
    // MySql 매장 IDX
    restaurantIdx: { type: Number },
    // 카테고리 명
    name: { type: String, required: true },
    // 노출 우선순위
    priority: { type: Number, required: true },
    // 삭제 여부
    isDeleted: { type: Boolean, required: true, default: false },
    // 카테고리 설명
    description: { type: String, default: '' },
    // Document 생성 일시
    createdAt: { type: Schema.Types.Date },
    // Document 수정 일시
    updatedAt: { type: Schema.Types.Date },
  },
  {
    timestamps: true,
    skipVersioning: true,
    versionKey: false,
    read: 'primary',
  },
);

MenuCategorySchema.virtual('menu', {
  ref: 'menu',
  localField: 'idx',
  foreignField: 'menuCategoryIdx',
});
MenuCategorySchema.set('toObject', { virtuals: true });
MenuCategorySchema.set('toJSON', { virtuals: true });

ref : 참고할 collection 

localField : 현재 스키마 (collection)에서 연결할 필드

foreignField : 참고할 collection 중 localField와 연결할 필드 

menuCategory의 Idx 필드 값은 menu collection의 필드 menuCategoryIdx와 값이 같다.

 

**  이래에 두 줄 toObject, toJSON 반드시 해줘야함. virtual 모델은 output값이 따로 없대! 

 

 

 

 

mongoose 

const getSortedCategoryListAndMenusByRestaurantIdx = async (
  restaurantIdx: number,
): Promise<IMenuCategory[]> => {
  return MenuCategoryModel.find(
    {
      restaurantIdx,
      isDeleted: false,
    },
    ['idx', 'name', 'priority'],
  )
    .sort([['priority', 'ASC']])
    .populate({
      path: 'menu',
      select: 'name dailySalesQuantity isSoldOut priority',
      match: {
        isDeleted: false,
        status: true,
        $or: [
          { useReservationOrder: true },
          { useWaitingOrder: true },
          { useTakeOutOrder: true },
          { useOnSiteOrder: true },
        ],
      },
      options: {
        sort: { priority: 1 },
      },
    })
    .exec();
};

 

 

 

반응형