代码之家  ›  专栏  ›  技术社区  ›  outis

是否可以使用多行的无表选择?

  •  7
  • outis  · 技术社区  · 14 年前

    SELECT 没有 FROM 子句在不查询表的情况下为我们获取多列:

    SELECT 17+23, REPLACE('bannanna', 'nn', 'n'), RAND(), CURRENT_TIMESTAMP;
    

    我们如何编写一个不引用表而导致多行的查询?基本上,虐待 选择 将其转换为数据定义语句。结果可以是单列或多列。

    我对DBMS中性答案最感兴趣,但其他答案(例如基于 UNPIVOT 欢迎光临。我想收集尽可能多的方法来做这个。这个问题背后没有技术应用;它比实际应用更理论化。

    3 回复  |  直到 12 年前
        1
  •  12
  •   martin clayton egrunin    14 年前

    使用A UNION :

    SELECT 1
    UNION
    SELECT 2
    

    在MySQL中如下所示:

    +---+
    | 1 |
    +---+
    | 1 | 
    | 2 | 
    +---+
    

    使用 UNION ALL 以避免丢失非唯一行。

        2
  •  16
  •   Martin Smith    12 年前

    你可以使用 Table Value Constructors 如果RDBMS支持的话。下面是一个例子 Mr Celko

    SELECT X.*
    FROM   (VALUES (1, 3.07766, 6.31371, 12.7062, 63.65600),
                   (2, 1.88562, 2.91999, 4.30265, 9.92482),
                   (3, 1.63774, 2.35336, 3.18243, 5.84089)) AS X (A, B, C, D, E); 
    
        3
  •  1
  •   outis    13 年前

    T-SQL UNPIVOT 无法将数据从行转置到列。多个非Pivot等价于每个非Pivoted列的笛卡尔积。

    SELECT N, S
      FROM (SELECT 1 aa, 2 ab, 3 ac, 'a' ba, 'b' bb, 'c' bc) s
      UNPIVOT (N for Num in (aa,ab,ac)) AS t
      UNPIVOT (S for Str in (ba,bb,bc)) AS u
    

    结果:

    N | S
    --+--
    1 | a
    1 | b
    1 | c
    2 | a
    2 | b
    2 | c
    3 | a
    3 | b
    3 | c