这两者之间最好的查询是什么?它们输出相同的结果,期望一个在 a 内执行条件where in
,另一个在 a 内执行inner join
。
select uv.* from version v inner join user_version uv ON v.id=uv.version_id
WHERE (v.number, v.master_id) IN (
select max(v.number) as number, v.master_id
from version v inner join user_version uv ON v.id=uv.version_id group by v.master_id);
和
select * from user_version uv
inner join version v on v.id=uv.version_id and v.number
inner join (
select uv2.user_id, max(v2.number) maxNumber, v2.master_id master_id, v2.id version_id from version v2
inner join user_version uv2 on v2.id=uv2.version_id group by v2.master_id ) test
on test.master_id=v.master_id and test.maxNumber=v.number ;
我已经创建了一个带有示例的 sqlfiddle:http ://sqlfiddle.com/#!2/76001/62 (这个想法是获取链接到给定用户的“主”实体的最大版本)
如果你有其他想法(我用的是mysql,所以不能用windows功能)
谢谢