gpt4 book ai didi

mysql - MONGODB:转换 SQL 联合查询

转载 作者:行者123 更新时间:2023-11-29 00:18:09 25 4
gpt4 key购买 nike

我正在从 MySql 转换到 MongoDB。现在我找不到这个查询的替代品:

(SELECT id, name, (score_kills - score_deaths) AS points FROM player ORDER BY points DESC LIMIT 10)
UNION
(SELECT id, name, (score_kills - score_deaths) AS points FROM player ORDER BY points ASC LIMIT 10);

这会选择 10 个最佳和最差的玩家,这些玩家按计算出的字段 points 排序。谁能帮我解决这个问题?

MongoDB 播放器中的文件如下所示:

{
_id: ObjectId("1234567890"),
name: "foo",
score_kills: 321,
score_deaths: 43
}

最佳答案

您可以使用聚合框架来做到这一点。在一个查询中执行此操作不会特别有效,因此您可能应该做与在运行两个查询的 SQL 中所做的相同的事情 - 唯一的区别是 MongoDB 不会将它们“联合”你,你必须在应用程序中这样做。

两个聚合查询是:

db.collection.aggregate( [
{$project:{name:1, points:{$subtract:["$score_kills","$score_deaths"]}}},
{$sort:{points:-1}},
{$limit:10}
]);

这将为您提供前 10 名。要获得后 10 名,您可以执行相同的操作,但按 {points:1} 排序,这将使您成为后 10 名。

关于mysql - MONGODB:转换 SQL 联合查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22122328/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com