42

私のクエリ:

SELECT sites.siteName, sites.siteIP, history.date
FROM sites INNER JOIN
     history ON sites.siteName = history.siteName
ORDER BY siteName,date

出力の最初の部分:

ここに画像の説明を入力

siteName列の重複を削除するにはどうすればよいですか? date列に基づいて更新されたものだけを残したい。

上記の出力例では、行 1、3、6、10 が必要です

4

3 に答える 3

47

ここでウィンドウ関数row_number()が役に立ちます。

SELECT s.siteName, s.siteIP, h.date
FROM sites s INNER JOIN
     (select h.*, row_number() over (partition by siteName order by date desc) as seqnum
      from history h
     ) h
    ON s.siteName = h.siteName and seqnum = 1
ORDER BY s.siteName, h.date
于 2013-07-06T23:09:44.167 に答える
8

siteIPあなたの例から、列が列によって決定されると仮定するのは合理的ですsiteName(つまり、各サイトには 1 つしかありませんsiteIP)。これが実際に当てはまる場合は、次を使用した簡単な解決策がありますgroup by

select
  sites.siteName,
  sites.siteIP,
  max(history.date)
from sites
inner join history on
  sites.siteName=history.siteName
group by
  sites.siteName,
  sites.siteIP
order by
  sites.siteName;

ただし、私の仮定が正しくない場合 (つまり、サイトに複数の がある可能性があります) 、2 番目の列でどのクエリを返したいsiteIPかという質問からは明確ではありません。siteIPだけの場合siteIP、次のクエリが実行されます。

select
  sites.siteName,
  min(sites.siteIP),
  max(history.date)
from sites
inner join history on
  sites.siteName=history.siteName
group by
  sites.siteName
order by
  sites.siteName;
于 2013-07-07T01:41:32.843 に答える