1

考虑以下查询:

SELECT (SELECT MIN(col1) FROM table1) = 7;

假设col1是不可为空的,这将产生真或假 - 或者当table1为空时可能为 NULL;

但现在假设我有:

SELECT (
  SELECT 
    FIRST_VALUE (col2) OVER (
        ORDER BY col1
    ) AS col2_for_first_col1
  FROM table1
) = 7;

(为了简单起见,假设col2也是不可为空的。)

col2如果最小值有唯一值col1,或者表是空的,那么这就像以前一样工作。但是如果最低值有多个 col2col1,我会得到一个查询运行时错误。

我的问题:NULL在多个内部查询结果的情况下,从最后一个查询中获取的简短、优雅的方法是什么?我当然可以复制它并检查计数,但我宁愿避免这样做。

重要警告:我使用的是 MonetDB,它似乎不支持ORDER BY ... LIMIT 1内部查询。

4

1 回答 1

1

如果没有 MonetDB 的限制,您似乎想要:

SELECT (SELECT col2
        FROM table1
        ORDER BY col1
        LIMIT 1
       ) = 7;

有了这个限制,您可以不同地使用窗口函数:

SELECT (SELECT col2
        FROM (SELECT col2, ROW_NUMBER() OVER (ORDER BY col1) as seqnum
              FROM table1
             ) t
        WHERE seqnum = 1
       ) = 7;
于 2021-04-23T16:43:01.363 回答