jstests/query_golden_sharding/expected_output/distinct_chunk_skipping.md
[
{
"$match" : {
"a" : {
"$gte" : "shard0"
},
"c" : {
"$eq" : 1
}
}
},
{
"$group" : {
"_id" : "$a"
}
}
]
{ "_id" : "shard0_1" }
{ "_id" : "shard0_2" }
{ "_id" : "shard1_2" }
[ "_id_", "a_1_c_1", "a_1_b_1_c_1" ]
{
"distinct_chunk_skipping-rs0" : [
{
"$cursor" : {
"rejectedPlans" : [
[
{
"stage" : "PROJECTION_COVERED",
"transformBy" : {
"_id" : 0,
"a" : 1
}
},
{
"direction" : "forward",
"indexBounds" : {
"a" : [
"[\"shard0\", {})"
],
"b" : [
"[MinKey, MaxKey]"
],
"c" : [
"[1.0, 1.0]"
]
},
"indexName" : "a_1_b_1_c_1",
"isFetching" : false,
"isMultiKey" : false,
"isPartial" : false,
"isShardFiltering" : false,
"isSparse" : false,
"isUnique" : false,
"keyPattern" : {
"a" : 1,
"b" : 1,
"c" : 1
},
"multiKeyPaths" : {
"a" : [ ],
"b" : [ ],
"c" : [ ]
},
"stage" : "DISTINCT_SCAN"
}
]
],
"winningPlan" : [
{
"stage" : "PROJECTION_COVERED",
"transformBy" : {
"_id" : 0,
"a" : 1
}
},
{
"direction" : "forward",
"indexBounds" : {
"a" : [
"[\"shard0\", {})"
],
"c" : [
"[1.0, 1.0]"
]
},
"indexName" : "a_1_c_1",
"isFetching" : false,
"isMultiKey" : false,
"isPartial" : false,
"isShardFiltering" : false,
"isSparse" : false,
"isUnique" : false,
"keyPattern" : {
"a" : 1,
"c" : 1
},
"multiKeyPaths" : {
"a" : [ ],
"c" : [ ]
},
"stage" : "DISTINCT_SCAN"
}
]
}
},
{
"$groupByDistinctScan" : {
"newRoot" : {
"_id" : "$a"
}
}
}
],
"queryShapeHash" : "2209486C2E1164C3906C2002ABE4D156E6CA7B9B8F8679EA27FE4B8E819792B5"
}
[
{
"$match" : {
"a" : {
"$gte" : "shard0"
},
"c" : {
"$eq" : 1
}
}
},
{
"$group" : {
"_id" : "$a"
}
}
]
{ "_id" : "shard0_1" }
{ "_id" : "shard0_2" }
{ "_id" : "shard1_2" }
[ "_id_", "a_1_c_1", "a_1_b_1_c_1" ]
{
"distinct_chunk_skipping-rs0" : [
{
"$cursor" : {
"rejectedPlans" : [
[
{
"stage" : "PROJECTION_COVERED",
"transformBy" : {
"_id" : 0,
"a" : 1
}
},
{
"direction" : "forward",
"indexBounds" : {
"a" : [
"[\"shard0\", {})"
],
"b" : [
"[MinKey, MaxKey]"
],
"c" : [
"[1.0, 1.0]"
]
},
"indexName" : "a_1_b_1_c_1",
"isFetching" : false,
"isMultiKey" : false,
"isPartial" : false,
"isShardFiltering" : true,
"isSparse" : false,
"isUnique" : false,
"keyPattern" : {
"a" : 1,
"b" : 1,
"c" : 1
},
"multiKeyPaths" : {
"a" : [ ],
"b" : [ ],
"c" : [ ]
},
"stage" : "DISTINCT_SCAN"
}
]
],
"winningPlan" : [
{
"direction" : "forward",
"indexBounds" : {
"a" : [
"[\"shard0\", {})"
],
"c" : [
"[1.0, 1.0]"
]
},
"indexName" : "a_1_c_1",
"isFetching" : true,
"isMultiKey" : false,
"isPartial" : false,
"isShardFiltering" : true,
"isSparse" : false,
"isUnique" : false,
"keyPattern" : {
"a" : 1,
"c" : 1
},
"multiKeyPaths" : {
"a" : [ ],
"c" : [ ]
},
"stage" : "DISTINCT_SCAN"
}
]
}
},
{
"$groupByDistinctScan" : {
"newRoot" : {
"_id" : "$a"
}
}
}
],
"distinct_chunk_skipping-rs1" : [
{
"$cursor" : {
"rejectedPlans" : [
[
{
"stage" : "PROJECTION_COVERED",
"transformBy" : {
"_id" : 0,
"a" : 1
}
},
{
"direction" : "forward",
"indexBounds" : {
"a" : [
"[\"shard0\", {})"
],
"b" : [
"[MinKey, MaxKey]"
],
"c" : [
"[1.0, 1.0]"
]
},
"indexName" : "a_1_b_1_c_1",
"isFetching" : false,
"isMultiKey" : false,
"isPartial" : false,
"isShardFiltering" : true,
"isSparse" : false,
"isUnique" : false,
"keyPattern" : {
"a" : 1,
"b" : 1,
"c" : 1
},
"multiKeyPaths" : {
"a" : [ ],
"b" : [ ],
"c" : [ ]
},
"stage" : "DISTINCT_SCAN"
}
]
],
"winningPlan" : [
{
"direction" : "forward",
"indexBounds" : {
"a" : [
"[\"shard0\", {})"
],
"c" : [
"[1.0, 1.0]"
]
},
"indexName" : "a_1_c_1",
"isFetching" : true,
"isMultiKey" : false,
"isPartial" : false,
"isShardFiltering" : true,
"isSparse" : false,
"isUnique" : false,
"keyPattern" : {
"a" : 1,
"c" : 1
},
"multiKeyPaths" : {
"a" : [ ],
"c" : [ ]
},
"stage" : "DISTINCT_SCAN"
}
]
}
},
{
"$groupByDistinctScan" : {
"newRoot" : {
"_id" : "$a"
}
}
}
],
"mergeType" : "router",
"mergerPart" : [
{
"$mergeCursors" : {
"allowPartialResults" : false,
"compareWholeSortKey" : false,
"nss" : "test.distinct_chunk_skipping",
"recordRemoteOpWaitTime" : false,
"requestQueryStatsFromRemotes" : false,
"tailableMode" : "normal"
}
},
{
"$group" : {
"$doingMerge" : true,
"_id" : "$$ROOT._id"
}
}
],
"queryShapeHash" : "2209486C2E1164C3906C2002ABE4D156E6CA7B9B8F8679EA27FE4B8E819792B5",
"shardsPart" : [
{
"$match" : {
"$and" : [
{
"a" : {
"$gte" : "shard0"
}
},
{
"c" : {
"$eq" : 1
}
}
]
}
},
{
"$group" : {
"_id" : "$a"
}
}
]
}
[
{
"$match" : {
"a" : {
"$gte" : "shard0"
},
"c" : {
"$lte" : 1
}
}
},
{
"$group" : {
"_id" : "$a"
}
}
]
{ "_id" : "shard0_1" }
{ "_id" : "shard0_2" }
{ "_id" : "shard0_3" }
{ "_id" : "shard1_1" }
{ "_id" : "shard1_2" }
[ "_id_", "a_1_c_1", "a_1_b_1_c_1" ]
{
"distinct_chunk_skipping-rs0" : [
{
"$cursor" : {
"rejectedPlans" : [
[
{
"direction" : "forward",
"indexBounds" : {
"a" : [
"[\"shard0\", {})"
],
"c" : [
"[-inf, 1.0]"
]
},
"indexName" : "a_1_c_1",
"isFetching" : true,
"isMultiKey" : false,
"isPartial" : false,
"isShardFiltering" : true,
"isSparse" : false,
"isUnique" : false,
"keyPattern" : {
"a" : 1,
"c" : 1
},
"multiKeyPaths" : {
"a" : [ ],
"c" : [ ]
},
"stage" : "DISTINCT_SCAN"
}
]
],
"winningPlan" : [
{
"stage" : "PROJECTION_COVERED",
"transformBy" : {
"_id" : 0,
"a" : 1
}
},
{
"direction" : "forward",
"indexBounds" : {
"a" : [
"[\"shard0\", {})"
],
"b" : [
"[MinKey, MaxKey]"
],
"c" : [
"[-inf, 1.0]"
]
},
"indexName" : "a_1_b_1_c_1",
"isFetching" : false,
"isMultiKey" : false,
"isPartial" : false,
"isShardFiltering" : true,
"isSparse" : false,
"isUnique" : false,
"keyPattern" : {
"a" : 1,
"b" : 1,
"c" : 1
},
"multiKeyPaths" : {
"a" : [ ],
"b" : [ ],
"c" : [ ]
},
"stage" : "DISTINCT_SCAN"
}
]
}
},
{
"$groupByDistinctScan" : {
"newRoot" : {
"_id" : "$a"
}
}
}
],
"distinct_chunk_skipping-rs1" : [
{
"$cursor" : {
"rejectedPlans" : [
[
{
"stage" : "PROJECTION_COVERED",
"transformBy" : {
"_id" : 0,
"a" : 1
}
},
{
"direction" : "forward",
"indexBounds" : {
"a" : [
"[\"shard0\", {})"
],
"b" : [
"[MinKey, MaxKey]"
],
"c" : [
"[-inf, 1.0]"
]
},
"indexName" : "a_1_b_1_c_1",
"isFetching" : false,
"isMultiKey" : false,
"isPartial" : false,
"isShardFiltering" : true,
"isSparse" : false,
"isUnique" : false,
"keyPattern" : {
"a" : 1,
"b" : 1,
"c" : 1
},
"multiKeyPaths" : {
"a" : [ ],
"b" : [ ],
"c" : [ ]
},
"stage" : "DISTINCT_SCAN"
}
]
],
"winningPlan" : [
{
"direction" : "forward",
"indexBounds" : {
"a" : [
"[\"shard0\", {})"
],
"c" : [
"[-inf, 1.0]"
]
},
"indexName" : "a_1_c_1",
"isFetching" : true,
"isMultiKey" : false,
"isPartial" : false,
"isShardFiltering" : true,
"isSparse" : false,
"isUnique" : false,
"keyPattern" : {
"a" : 1,
"c" : 1
},
"multiKeyPaths" : {
"a" : [ ],
"c" : [ ]
},
"stage" : "DISTINCT_SCAN"
}
]
}
},
{
"$groupByDistinctScan" : {
"newRoot" : {
"_id" : "$a"
}
}
}
],
"mergeType" : "router",
"mergerPart" : [
{
"$mergeCursors" : {
"allowPartialResults" : false,
"compareWholeSortKey" : false,
"nss" : "test.distinct_chunk_skipping",
"recordRemoteOpWaitTime" : false,
"requestQueryStatsFromRemotes" : false,
"tailableMode" : "normal"
}
},
{
"$group" : {
"$doingMerge" : true,
"_id" : "$$ROOT._id"
}
}
],
"queryShapeHash" : "B9BC1E78DD6A3A08A3F84BAFFEFAEDBFFFE732B016DE718C9C056C098CADA9CA",
"shardsPart" : [
{
"$match" : {
"$and" : [
{
"a" : {
"$gte" : "shard0"
}
},
{
"c" : {
"$lte" : 1
}
}
]
}
},
{
"$group" : {
"_id" : "$a"
}
}
]
}
[
{
"$match" : {
"a" : {
"$gte" : "shard0"
},
"c" : {
"$eq" : 1
}
}
},
{
"$group" : {
"_id" : "$a"
}
}
]
{ "_id" : "shard0_1" }
{ "_id" : "shard0_2" }
{ "_id" : "shard1_2" }
[ "_id_", "a_1_c_1", "a_1_b_1_c_1", "c_1" ]
{
"distinct_chunk_skipping-rs0" : [
{
"$cursor" : {
"rejectedPlans" : [
[
{
"stage" : "PROJECTION_COVERED",
"transformBy" : {
"_id" : 0,
"a" : 1
}
},
{
"direction" : "forward",
"indexBounds" : {
"a" : [
"[\"shard0\", {})"
],
"b" : [
"[MinKey, MaxKey]"
],
"c" : [
"[1.0, 1.0]"
]
},
"indexName" : "a_1_b_1_c_1",
"isFetching" : false,
"isMultiKey" : false,
"isPartial" : false,
"isShardFiltering" : true,
"isSparse" : false,
"isUnique" : false,
"keyPattern" : {
"a" : 1,
"b" : 1,
"c" : 1
},
"multiKeyPaths" : {
"a" : [ ],
"b" : [ ],
"c" : [ ]
},
"stage" : "DISTINCT_SCAN"
}
],
[
{
"direction" : "forward",
"indexBounds" : {
"a" : [
"[\"shard0\", {})"
],
"c" : [
"[1.0, 1.0]"
]
},
"indexName" : "a_1_c_1",
"isFetching" : true,
"isMultiKey" : false,
"isPartial" : false,
"isShardFiltering" : true,
"isSparse" : false,
"isUnique" : false,
"keyPattern" : {
"a" : 1,
"c" : 1
},
"multiKeyPaths" : {
"a" : [ ],
"c" : [ ]
},
"stage" : "DISTINCT_SCAN"
}
]
],
"winningPlan" : [
{
"stage" : "PROJECTION_SIMPLE",
"transformBy" : {
"_id" : 0,
"a" : 1
}
},
{
"stage" : "SHARDING_FILTER"
},
{
"filter" : {
"a" : {
"$gte" : "shard0"
}
},
"nss" : "test.distinct_chunk_skipping",
"stage" : "FETCH"
},
{
"direction" : "forward",
"indexBounds" : {
"c" : [
"[1.0, 1.0]"
]
},
"indexName" : "c_1",
"isMultiKey" : false,
"isPartial" : false,
"isSparse" : false,
"isUnique" : false,
"keyPattern" : {
"c" : 1
},
"multiKeyPaths" : {
"c" : [ ]
},
"nss" : "test.distinct_chunk_skipping",
"stage" : "IXSCAN"
}
]
}
},
{
"$group" : {
"_id" : "$a"
}
}
],
"distinct_chunk_skipping-rs1" : [
{
"$cursor" : {
"rejectedPlans" : [
[
{
"stage" : "PROJECTION_COVERED",
"transformBy" : {
"_id" : 0,
"a" : 1
}
},
{
"direction" : "forward",
"indexBounds" : {
"a" : [
"[\"shard0\", {})"
],
"b" : [
"[MinKey, MaxKey]"
],
"c" : [
"[1.0, 1.0]"
]
},
"indexName" : "a_1_b_1_c_1",
"isFetching" : false,
"isMultiKey" : false,
"isPartial" : false,
"isShardFiltering" : true,
"isSparse" : false,
"isUnique" : false,
"keyPattern" : {
"a" : 1,
"b" : 1,
"c" : 1
},
"multiKeyPaths" : {
"a" : [ ],
"b" : [ ],
"c" : [ ]
},
"stage" : "DISTINCT_SCAN"
}
],
[
{
"direction" : "forward",
"indexBounds" : {
"a" : [
"[\"shard0\", {})"
],
"c" : [
"[1.0, 1.0]"
]
},
"indexName" : "a_1_c_1",
"isFetching" : true,
"isMultiKey" : false,
"isPartial" : false,
"isShardFiltering" : true,
"isSparse" : false,
"isUnique" : false,
"keyPattern" : {
"a" : 1,
"c" : 1
},
"multiKeyPaths" : {
"a" : [ ],
"c" : [ ]
},
"stage" : "DISTINCT_SCAN"
}
]
],
"winningPlan" : [
{
"stage" : "PROJECTION_SIMPLE",
"transformBy" : {
"_id" : 0,
"a" : 1
}
},
{
"stage" : "SHARDING_FILTER"
},
{
"filter" : {
"a" : {
"$gte" : "shard0"
}
},
"nss" : "test.distinct_chunk_skipping",
"stage" : "FETCH"
},
{
"direction" : "forward",
"indexBounds" : {
"c" : [
"[1.0, 1.0]"
]
},
"indexName" : "c_1",
"isMultiKey" : false,
"isPartial" : false,
"isSparse" : false,
"isUnique" : false,
"keyPattern" : {
"c" : 1
},
"multiKeyPaths" : {
"c" : [ ]
},
"nss" : "test.distinct_chunk_skipping",
"stage" : "IXSCAN"
}
]
}
},
{
"$group" : {
"_id" : "$a"
}
}
],
"mergeType" : "router",
"mergerPart" : [
{
"$mergeCursors" : {
"allowPartialResults" : false,
"compareWholeSortKey" : false,
"nss" : "test.distinct_chunk_skipping",
"recordRemoteOpWaitTime" : false,
"requestQueryStatsFromRemotes" : false,
"tailableMode" : "normal"
}
},
{
"$group" : {
"$doingMerge" : true,
"_id" : "$$ROOT._id"
}
}
],
"queryShapeHash" : "2209486C2E1164C3906C2002ABE4D156E6CA7B9B8F8679EA27FE4B8E819792B5",
"shardsPart" : [
{
"$match" : {
"$and" : [
{
"a" : {
"$gte" : "shard0"
}
},
{
"c" : {
"$eq" : 1
}
}
]
}
},
{
"$group" : {
"_id" : "$a"
}
}
]
}