これら2つの間で最適なクエリは何ですか? where in
それらは同じ結果を出力します。一方が a 内で条件を実行し、もう一方が an 内で条件を実行していることを期待して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関数は使用できません)
ありがとう