sql >> Databáze >  >> RDS >> Mysql

seskupit podle hodnot, které nejsou null

Myslím, že následující dělá to, co chcete:

SELECT *, (To_days(date_expires)-TO_DAYS(NOW())) as dayDiff, COUNT(id) AS change_count
FROM mytable
GROUP BY (case when source_id is null then id else source_id end)
HAVING dayDiff < 4 
ORDER BY (case when source_id is null then 1 else 0 end), date_created DESC

Provádí podmíněné group by takže NULL sourceids nebudou seskupeny. Potom je umístí na poslední místo pomocí logiky v order by .

Nepochopil jsem, co jsi myslel tím posledním výskytem. Teď si myslím, že ano:

SELECT coalesce(s.id, mytable.id) as id,
       max(case when s.maxid is not null and s.maxid = myable.id then mytable.name
                when s.maxid is null then NULL
                else mytable.name
           end) as name,
       (To_days(date_expires)-TO_DAYS(NOW())) as dayDiff, COUNT(id) AS change_count
FROM mytable left outer join
     (select source_id, MAX(id) as maxid
      from mytable
      where source_id is not null
      group by source_id
     ) s
     on mytable.id = s.maxid
GROUP BY (case when source_id is null then id else source_id end)
HAVING dayDiff < 4 
ORDER BY (case when source_id is null then 1 else 0 end), date_created DESC

Tím se připojí informace z posledního záznamu (na základě nejvyššího id).



  1. postgres:upgradovat uživatele na superuživatele?

  2. Proč dostanu výjimku OutOfRange ve funkci GetOrdinal tohoto pole CLOB?

  3. Jak vyplnit prázdnou hodnotu, když v daný den není žádný záznam pomocí MySQL group by

  4. Výkon Mysql Query. který je nejlepší?