是否可以进行多行无表选择?

时间:2010-05-22 00:38:12

标签: sql

没有SELECT子句的FROM会在没有查询表的情况下为我们提供多列:

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

如何在不引用表的情况下编写导致多行的查询?基本上,滥用SELECT将其转换为数据定义语句。结果可能只有一列或多列。

我最感兴趣的是DBMS中立答案,但其他人(例如基于UNPIVOT)是受欢迎的。我想收集尽可能多的方法来做到这一点。这个问题背后没有技术应用;它更具理论性而非实际性。

3 个答案:

答案 0 :(得分:16)

如果您的RDBMS支持,您可以使用Table Value Constructors。以下是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); 

答案 1 :(得分:12)

使用UNION

SELECT 1
UNION
SELECT 2

在MySQL中看起来像这样:

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

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

答案 2 :(得分:1)

T-SQL的UNPIVOT可以将数据从行转换为列。多个unpivot相当于每个不透明列的笛卡尔积。

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