Генерация последовательных date_time за минуту в MySQL - PullRequest
0 голосов
/ 19 января 2019

Я использую приведенный ниже MySQL, найденный в Интернете, чтобы сгенерировать список дат.Тем не менее, я хочу, чтобы он генерировал список date_times за минуту, например, гггг-мм-дд чч: мм: сс.Это возможно?Я не могу понять, как существующий SQL генерирует список, не говоря уже о добавлении минут!

Мне нужно это для моего базового запроса для диаграммы / графика, использующего левое соединение для извлечения данных из других источников.

Спасибо

select * from 
(select adddate('1970-01-01',t4.i*10000 + t3.i*1000 + t2.i*100 + t1.i*10 + t0.i) selected_date from
 (select 0 i union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t0,
 (select 0 i union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t1,
 (select 0 i union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t2,
 (select 0 i union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t3,
 (select 0 i union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9) t4) v
where selected_date between '2019-01-01' and '2019-01-15'

Текущий вывод:

selected_date
---
2019-01-01
2019-01-02
2019-01-03
2019-01-04

Требуемый вывод:

selected_date
---
2019-01-19 00:05:00
2019-01-19 00:06:00
2019-01-19 00:07:00
2019-01-19 00:08:00
2019-01-19 00:09:00
2019-01-19 00:10:00
2019-01-19 00:11:00

Редактировать: Это мой SQL-запрос, обслуживающий график,Я получаю 5-6 записей температуры в минуту, поэтому я их усредняю.Иногда у меня возникает проблема с температурным датчиком, поэтому a.date_time или b.date_time не имеют последовательных date_time для каждой отдельной минуты

    select 
        b.date_time,
        a.temperature as fishtank,
        b.temperature as room
    from (
        select
            serial,
            convert((min(date_time) div 100)*100, datetime)  as date_time, 
            avg(temperature) as temperature
        from
            raspicontroller.temperature
        WHERE 
            date_time between '$date_from' and '$date_to' and 
            serial like '28-000898430d59'
        group by 
            date_time div 100
    ) a
    right join (
        select
            serial,
            convert((min(date_time) div 100)*100, datetime)  as date_time, 
            avg(temperature) as temperature
        from
            raspicontroller.temperature
        WHERE 
            date_time between '$date_from' and '$date_to' and 
            serial like '28-000f9843201e'
        group by 
            date_time div 100
    ) b on a.date_time = b.date_time

Редактировать снова: мне не удалось сгенерировать то, что яхотел, однако я пришел с этим, который использует существующие значения в БД для перечисления дат.Я думаю, что это будет работать для меня

SELECT
    a.date_time,
    b.temperature as FishTank,
    c.temperature as Room
FROM (
    select
        convert((min(date_time) div 100)*100, datetime)  as date_time
    from
        raspicontroller.temperature
    group by 
        date_time div 100
) as a
LEFT JOIN (
    select
        serial,
        convert((min(date_time) div 100)*100, datetime)  as date_time, 
        avg(temperature) as temperature
    from
        raspicontroller.temperature
    WHERE
        serial like '28-000898430d59'
    group by 
        date_time div 100
) as b on a.date_time = b.date_time
LEFT JOIN (
    select
        serial,
        convert((min(date_time) div 100)*100, datetime)  as date_time, 
        avg(temperature) as temperature
    from
        raspicontroller.temperature
    WHERE
        serial like '28-000f9843201e'
    group by 
        date_time div 100
) as c on a.date_time = c.date_time
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...