我想做这样的事情:
select data AS curdate() from table;
所以结果表看起来像:
2013-04-26
data 1
data 2
data 3
我无法弄清楚语法,但它必须是可能的?
我已经尝试过没有任何类型的引号,这会返回错误。单引号和反引号都返回 SQL 本身作为列标题。
我想做这样的事情:
select data AS curdate() from table;
所以结果表看起来像:
2013-04-26
data 1
data 2
data 3
我无法弄清楚语法,但它必须是可能的?
我已经尝试过没有任何类型的引号,这会返回错误。单引号和反引号都返回 SQL 本身作为列标题。
这是一个不寻常的要求,但如果您坚持,您将不得不使用动态 sql。
SET @curdate = CURDATE();
SET @sql = CONCAT('SELECT whatever AS "', @curdate, '" FROM whatever');
PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
别名被视为标识符,如果不使用动态 SQL,则无法将其分配给函数。它会破坏引用,例如:
SELECT *
FROM (SELECT 1 AS curdate()) a