mongodb 通過嵌入文檔中的字段排序


 

mongodb中的全部數據:

db.testInfo.find({})
.sort({_id:-1})
.limit(100)

查詢結果:

/* 1 createdAt:2019/10/11 下午5:12:50*/
{
	"_id" : ObjectId("5da04792665cd81dc0d46d3d"),
	"name" : "jim2",
	"age" : 5,
	"list" : [
		{
			"title" : "a2",
			"price" : 1
		},
		{
			"title" : "a1",
			"price" : 5
		}
	]
},

/* 2 createdAt:2019/10/11 下午5:01:55*/
{
	"_id" : ObjectId("5da04503665cd81dc0d46d3c"),
	"name" : "leo",
	"age" : 4,
	"list" : [
		{
			"title" : "a1",
			"price" : 3
		},
		{
			"title" : "d2",
			"price" : 2
		}
	]
},

/* 3 createdAt:2019/10/11 下午5:01:55*/
{
	"_id" : ObjectId("5da04503665cd81dc0d46d3b"),
	"name" : "jason",
	"age" : 3,
	"list" : [
		{
			"title" : "a1",
			"price" : 2
		},
		{
			"title" : "c2",
			"price" : 1
		}
	]
},

/* 4 createdAt:2019/10/11 下午5:01:55*/
{
	"_id" : ObjectId("5da04503665cd81dc0d46d3a"),
	"name" : "mark",
	"age" : 2,
	"list" : [
		{
			"title" : "a1",
			"price" : 3
		},
		{
			"title" : "b2",
			"price" : 4
		}
	]
},

/* 5 createdAt:2019/10/11 下午5:00:12*/
{
	"_id" : ObjectId("5da0449c665cd81dc0d46d39"),
	"name" : "jim",
	"age" : 1,
	"list" : [
		{
			"title" : "a1",
			"price" : 1
		},
		{
			"title" : "a2",
			"price" : 2
		}
	]
}

 

通過嵌入文檔中查詢指定title的數據,然后根據price排序,注意需要排序時將查詢的title也一並作為排序字段,否則順序會錯亂。

db.testInfo.find({"list.title":"a1"})
.sort({
    "list.title":1,
    "list.price":1
});

查詢結果:

/* 1 createdAt:2019/10/11 下午5:00:12*/
{
	"_id" : ObjectId("5da0449c665cd81dc0d46d39"),
	"name" : "jim",
	"age" : 1,
	"list" : [
		{
			"title" : "a1",
			"price" : 1
		},
		{
			"title" : "a2",
			"price" : 2
		}
	]
},

/* 2 createdAt:2019/10/11 下午5:01:55*/
{
	"_id" : ObjectId("5da04503665cd81dc0d46d3b"),
	"name" : "jason",
	"age" : 3,
	"list" : [
		{
			"title" : "a1",
			"price" : 2
		},
		{
			"title" : "c2",
			"price" : 1
		}
	]
},

/* 3 createdAt:2019/10/11 下午5:01:55*/
{
	"_id" : ObjectId("5da04503665cd81dc0d46d3a"),
	"name" : "mark",
	"age" : 2,
	"list" : [
		{
			"title" : "a1",
			"price" : 3
		},
		{
			"title" : "b2",
			"price" : 4
		}
	]
},

/* 4 createdAt:2019/10/11 下午5:01:55*/
{
	"_id" : ObjectId("5da04503665cd81dc0d46d3c"),
	"name" : "leo",
	"age" : 4,
	"list" : [
		{
			"title" : "a1",
			"price" : 3
		},
		{
			"title" : "d2",
			"price" : 2
		}
	]
},

/* 5 createdAt:2019/10/11 下午5:12:50*/
{
	"_id" : ObjectId("5da04792665cd81dc0d46d3d"),
	"name" : "jim2",
	"age" : 5,
	"list" : [
		{
			"title" : "a2",
			"price" : 1
		},
		{
			"title" : "a1",
			"price" : 5
		}
	]
}

目前好像根據經緯度范圍查詢時,無法同時指定嵌入文檔中的字段正確排序。只能先通過經緯度范圍查詢出來所有數據后,再根據嵌入文檔中字段進行排序。

特殊情況下是否可以考慮固定嵌入集合數量,指定下標來對應字段排序(未測試過)。

學藝不精,如有其他辦法,歡迎留言一起討論。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM