gpt4 book ai didi

MySQL 在多个表中选择不同的值

转载 作者:行者123 更新时间:2023-11-29 01:01:36 24 4
gpt4 key购买 nike

我有两个表:

table_1
uid | xid | name

table_2
uid | elements | time | pkey

我想选择多行 xid、元素和时间,其中时间是 10 个最小值且 uid(或 xid)不同。

table_1中的uid、xid是唯一的,table_1和table_2中的uid是一对多的关系..

我试过这样的东西,但效果不是很好:

SELECT table_1.xid, MIN(table_2.time), table_2.elements
FROM table_1, table_2
WHERE table_1.uid= table_2.uid
GROUP BY table_2.uid
LIMIT 10

让我们拿一些数据来玩一下:

table_1
uid | xid | name
1 | 435 | John
2 | 596 | Jane


table_2
uid | elements | time | pkey
1 | 1 | 567 | 0
2 | 2 | 335 | 1
1 | 1 | 435 | 2
1 | 2 | 456 | 3
2 | 1 | 337 | 4
1 | 1 | 428 | 5

我如何为每个 UID 选择前 2 个不同的结果?在这种情况下:

fid| elements | time
596| 2 | 335
435| 1 | 428

谢谢!!!

如果人们不明白为什么 lexu 的解决方案不起作用 - 它没有绑定(bind)到表 2 上的主键

如果我将以上数据更改为:

table_2
uid | elements | time | pkey
1 | 1 | 567 | 0
2 | 2 | 335 | 1
1 | 1 | 435 | 2
1 | 2 | 456 | 3
2 | 1 | 337 | 4
1 | 2 | 428 | 5

保持 table_1 不变,结果应该是:

fid| elements | time
596| 2 | 335
435| 2 | 428

但是@lexu 的解决方案结果是:

fid| elements | time
596| 2 | 335
435| 1 | 428

尽管如此,还是感谢大家的帮助,尤其是@eagle!

最佳答案

这是我的解决方案。我认为我将逐步完成我的思考过程和我在每个步骤中尝试的查询,而不仅仅是给出工作查询:

首先,让我们为不同的 uid 选择 10 个最小的时间:

select uid, min(time)
from table_2
group by uid
order by 2
limit 10

这给了我们:

uid | time
2 | 335
1 | 428

这很容易......不幸的是,这不允许我们获取主键,如果添加以下行,这将是一个问题:

table_2
uid | elements | time | pkey
1 | 2 | 428 | 6

在以后的查询中,当我们尝试加入 timeuid 时,我们会得到两条记录而不是一条。所以我们需要一个更好的查询来返回一个不同的值(例如 pkey)而不是 time,我假设它可能是非不同的...

注意:如果 MySQL 有 FIRST()LAST() 聚合函数,这会简单得多。不幸的是,事实并非如此,所以我们必须满足于子查询、排序、限制组合。

select
t2.uid,
(select pkey from table_2 t3 where t2.uid = t3.uid order by t3.time asc limit 1) as minpkey
from
(select uid, min(time) from table_2 group by uid order by 2 limit 10) t2

这将返回我们可以使用的结果:

uid | minpkey
1 | 5
2 | 1

请注意,5 是随机选择的,而 6 也可以很容易地选择;这完全取决于 mysql 如何决定选择它。但对我们来说,这并不重要。

接下来我们要显示更多数据(即 xidelements 字段):

select t1.xid as fid, t5.elements, t5.time
from
(select
t2.uid,
(select pkey from table_2 t3 where t2.uid = t3.uid order by t3.time asc limit 1) as minpkey
from
(select uid, min(time) from table_2 group by uid order by 2 limit 10) t2
) t4
inner join table_1 t1 on (t4.uid = t1.uid)
inner join table_2 t5 on (t4.minpkey = t5.pkey)

中提琴,它应该返回您在示例中提供的完全相同的数据!它可能不是很有效,但应该可以!

关于MySQL 在多个表中选择不同的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2779281/

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