нужна помощь в написании запроса (реструктуризация таблицы) - PullRequest
1 голос
/ 01 августа 2020

Мне нужно написать оператор выбора, который перепишет таблицу следующим образом ... Я не уверен, как go об этом, используя MySQL.

Пример таблицы

user_id   date         a    b    c     
123456    2020-01-01   1    1    1
234567    2020-03-04   1    0    0
453576    2020-05-05   1    0    1

Желаемый результат

user_id   date        results
123456    2020-01-01  a
123456    2020-01-01  b
123456    2020-01-01  c
234567    2020-03-04  a
453576    2020-05-05  a
453576    2020-05-05  c

Ответы [ 2 ]

3 голосов
/ 01 августа 2020

В MySQL вы можете развернуть с помощью union all, при фильтрации по 1 значениям:

select user_id, date, 'a' as result from mytable where a = 1
union all select user_id, date, 'b' from mytable where b = 1
union all select user_id, date, 'c' from mytable where c = 1
order by user_id, date, result
1 голос
/ 01 августа 2020

Если у вас большой объем данных или ваша «таблица» действительно представляет собой сложный запрос (скажем, подзапрос или представление), то отключение обычно происходит быстрее с cross join, чем с union all:

select t.user_id, t.date, r.result
from t cross join
     (select 'a' as result union all
      select 'b' as result union all
      select 'c' as result 
     ) r
where (t.a = 1 and r.result = 'a') or
      (t.b = 1 and r.result = 'b') or
      (t.c = 1 and r.result = 'c') ;

Для одной таблицы smalli sh производительность, вероятно, не имеет значения.

...