SELECT没有FROM子句的A 会在不查询表的情况下为我们提供多列:
SELECT 17+23, REPLACE('bannanna', 'nn', 'n'), RAND(), CURRENT_TIMESTAMP;
Run Code Online (Sandbox Code Playgroud)
如何在不引用表的情况下编写导致多行的查询?基本上,滥用SELECT将其转换为数据定义语句.结果可能有一列或多列.
我最感兴趣的是DBMS中立答案,但其他人(例如基于UNPIVOT)是受欢迎的.我想收集尽可能多的方法来做到这一点.这个问题背后没有技术应用; 它更具理论性而非实用性.
Mar*_*ith 16
如果您的RDBMS支持,您可以使用表值构造函数.以下是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);
Run Code Online (Sandbox Code Playgroud)
mar*_*ton 12
使用UNION:
SELECT 1
UNION
SELECT 2
Run Code Online (Sandbox Code Playgroud)
在MySQL中看起来像这样:
+---+
| 1 |
+---+
| 1 |
| 2 |
+---+
Run Code Online (Sandbox Code Playgroud)
使用UNION ALL以避免非唯一行的损失.
| 归档时间: |
|
| 查看次数: |
4332 次 |
| 最近记录: |