Следующий запрос может дать нам ожидаемый результат:
db.collection.aggregate([
{
$unwind:"$isuLists"
},
{
$group:{
"_id":"$isuLists.isuSrtCd",
"min_stock":{
$min:{
"lwprc":"$isuLists.lwprc",
"trdTm":"$trdTm"
}
},
"max_stock":{
$max:{
"hgprc":"$isuLists.hgprc",
"trdTm":"$trdTm"
}
}
}
},
{
$project:{
"hgTm":"$max_stock.trdTm",
"lwTm":"$min_stock.trdTm"
}
}
]).pretty()
Набор данных:
{
"_id" : ObjectId("5d8db3700a1650f211831f16"),
"isuLists" : [
{
"hgprc" : 8100,
"isuSrtCd" : "000020",
"lwprc" : 8100,
"opnprc" : 8100,
"trdPrc" : 8100
},
{
"hgprc" : 0,
"isuSrtCd" : "000040",
"lwprc" : 0,
"opnprc" : 0,
"trdPrc" : 500
},
{
"hgprc" : 10050,
"isuSrtCd" : "000050",
"lwprc" : 10050,
"opnprc" : 10050,
"trdPrc" : 10050
},
{
"hgprc" : 0,
"isuSrtCd" : "700001",
"lwprc" : 0,
"opnprc" : 0,
"trdPrc" : 9305
},
{
"hgprc" : 3310,
"isuSrtCd" : "900140",
"lwprc" : 3310,
"opnprc" : 3310,
"trdPrc" : 3310
}
],
"trdDd" : "20190927",
"trdTm" : "090000"
}
{
"_id" : ObjectId("5d8d51000a1650f211826c9a"),
"isuLists" : [
{
"hgprc" : 8130,
"isuSrtCd" : "000020",
"lwprc" : 7880,
"opnprc" : 8100,
"trdPrc" : 7980
},
{
"hgprc" : 508,
"isuSrtCd" : "000040",
"lwprc" : 498,
"opnprc" : 504,
"trdPrc" : 500
},
{
"hgprc" : 10050,
"isuSrtCd" : "000050",
"lwprc" : 9720,
"opnprc" : 10050,
"trdPrc" : 9780
},
{
"hgprc" : 0,
"isuSrtCd" : "700001",
"lwprc" : 0,
"opnprc" : 0,
"trdPrc" : 9305
},
{
"hgprc" : 3310,
"isuSrtCd" : "900140",
"lwprc" : 3230,
"opnprc" : 3265,
"trdPrc" : 3300
}
],
"trdDd" : "20190927",
"trdTm" : "155959"
}
{
"_id" : ObjectId("5d9331cef2e6411a68a145eb"),
"isuLists" : [
{
"hgprc" : 8030,
"isuSrtCd" : "000020",
"lwprc" : 10,
"opnprc" : 8100,
"trdPrc" : 7980
},
{
"hgprc" : 508,
"isuSrtCd" : "000040",
"lwprc" : 498,
"opnprc" : 504,
"trdPrc" : 500
},
{
"hgprc" : 10050,
"isuSrtCd" : "000050",
"lwprc" : 9720,
"opnprc" : 10050,
"trdPrc" : 9780
},
{
"hgprc" : 0,
"isuSrtCd" : "700001",
"lwprc" : 0,
"opnprc" : 0,
"trdPrc" : 9305
},
{
"hgprc" : 3310,
"isuSrtCd" : "900140",
"lwprc" : 3230,
"opnprc" : 3265,
"trdPrc" : 3300
}
],
"trdDd" : "20190927",
"trdTm" : "155960"
}
Выход:
{ "_id" : "900140", "hgTm" : "155960", "lwTm" : "155959" }
{ "_id" : "000020", "hgTm" : "155959", "lwTm" : "155960" }
{ "_id" : "700001", "hgTm" : "155960", "lwTm" : "090000" }
{ "_id" : "000040", "hgTm" : "155960", "lwTm" : "090000" }
{ "_id" : "000050", "hgTm" : "155960", "lwTm" : "155959" }