5

我正在使用 PARTITION BY 子句对结果进行排序。此问题Sql Order by on multiple column中提到了使用 PARTITION BY 的详细信息。当我在 Oracle 中运行时,它工作正常。我将 H2 db 用于我的单元测试用例。当我在 H2 db 上运行相同的查询时,它不起作用。是 H2 中的已知问题吗?是否有任何替代解决方案可以在 Oracle 和 H2 中运行。

4

1 回答 1

6

我认为 H2 不支持窗口函数(也称为分析函数)。但是,您可以使用标准 SQL 在链接中进行查询:

SELECT t.*
FROM yourtable t join
     (select vendorname, max(incidentdate) as maxdate
      from yourtable yt
      group by vendorname
     ) vn
     on vn.vendorname = yt.vendorname
ORDER BY vn.maxDate DESC, t.VendorName ASC, t.IncidentDate DESC;

虽然这应该在两种环境中运行,但over表单在 SQL 中的性能可能更好。

于 2013-06-05T01:41:29.217 回答