Mysql
 sql >> Base de données >  >> RDS >> Mysql

mysql - Alias ​​de colonne dynamique

La réponse est simple :ce n'est pas possible en SQL. Les alias de colonne sont des constantes. Vous devrez créer la requête dynamiquement pour obtenir ce que vous voulez :

SET @column_alias1 := NOW() - INTERVAL 1 WEEK;
SET @column_alias2 := NOW() - INTERVAL 2 WEEK;
SET @query := CONCAT('SELECT SUM(...) AS `', @column_alias1, '`, SUM(...) AS `', @column_alias2, '` FROM ...');
PREPARE dynamic_statement FROM @query;
EXECUTE dynamic_statement;