MySQL повторно использовал переменные выводит NULL
Я использую следующий SQL. Столбец 1, столбец 2 дает выходные данные, такие как 122,5014 и 4,2857; Но последний столбец дает вывод NULL, хотя я ожидал 48,9266.
SQL INPUT:
SELECT (
SELECT @h := ( SUM( (
TIME_TO_SEC( TIMEDIFF( `stop` , `start` ) ) /3600 ) )
)
) AS `HoursWorked` , (
SELECT @w := ( TIMESTAMPDIFF(
DAY , MIN( `start` ) , MAX( `stop` ) ) /7 )
) AS `InWeeks` , (
SELECT (
((@w *40) - ( @h ))
)
) AS `DutyDistance`
FROM `work_table`
ВЫХОД:
HoursWorked | InWeeks | DutyDistance
------------------------------------
122.5014 | 4.2857 | NULL
1 ответ
Вывод пользовательских переменных непредсказуем при вычислении с помощью агрегатных функций и последующем использовании в выражении. И, следовательно, ваш запрос не работает.
Пример:
mysql> create table tbl_so_q23870035( i int );
Query OK, 0 rows affected (0.48 sec)
mysql> insert into tbl_so_q23870035 values( 2 ), ( 4 ), ( 9 ), ( 6 ), ( 15 );
Query OK, 5 rows affected (0.13 sec)
Records: 5 Duplicates: 0 Warnings: 0
mysql> select @s:=sum(i) as s, @s*2 as s2 from tbl_so_q23870035;
+------+------+
| s | s2 |
+------+------+
| 36 | NULL |
+------+------+
1 row in set (0.00 sec)
mysql> select s, s*2 as s2
-> from (
-> select sum(i) as s from tbl_so_q23870035
-> ) aggregated_data;
+------+------+
| s | s2 |
+------+------+
| 36 | 72 |
+------+------+
1 row in set (0.00 sec)
Следовательно, вы должны сначала изменить свой запрос, чтобы рассчитать HoursWorked
, а также InWeeks
во внутреннем запросе, а затем, во-вторых, рассчитать DutyDistance
во внешнем запросе. Пользовательская переменная не требуется.
Пример:
select `HoursWorked`, `InWeeks`, ( `InWeeks` * 40 - `HoursWorked` ) AS `DutyDistance`
from (
select SUM( TIME_TO_SEC( TIMEDIFF( `stop`, `start` ) ) / 3600 ) AS `HoursWorked`
, TIMESTAMPDIFF( DAY , MIN( `start` ), MAX( `stop` ) ) / 7 AS `InWeeks`
FROM `work_table`
) aggregated_data