2

我想做这样的事情:

select data AS curdate() from table;

所以结果表看起来像:

2013-04-26
  data 1
  data 2
  data 3

我无法弄清楚语法,但它必须是可能的?

我已经尝试过没有任何类型的引号,这会返回错误。单引号和反引号都返回 SQL 本身作为列标题。

4

2 回答 2

3

这是一个不寻常的要求,但如果您坚持,您将不得不使用动态 sql。

SET @curdate = CURDATE();
SET @sql = CONCAT('SELECT whatever AS "', @curdate, '" FROM whatever');

PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
于 2013-04-26T18:50:19.723 回答
0

别名被视为标识符,如果不使用动态 SQL,则无法将其分配给函数。它会破坏引用,例如:

SELECT *
FROM (SELECT 1 AS curdate()) a
于 2013-04-26T18:45:19.680 回答