Heim  >  Fragen und Antworten  >  Hauptteil

Java – Zählen Sie die täglichen Klicks der Top-Ten-Anzeigen von 20170403 bis 20170420

Es gibt eine Werbetabelle „advertise“ (advertise_id, date, count), die Daten lauten wie folgt:

Ich muss die Anzahl der Klicks pro Tag für die Top-10-Anzeigen innerhalb eines bestimmten Zeitraums berechnen.

Das Ergebnis der Abfrage sollte sein, dass es jeden Tag 10 Daten mit unterschiedlichen Advertisement-IDs gibt. Wie soll diese SQL geschrieben werden?

世界只因有你世界只因有你2736 Tage vor622

Antworte allen(2)Ich werde antworten

  • 天蓬老师

    天蓬老师2017-05-17 10:10:03

    有个问题是没出现在记录中的广告日期点击数显不显示,如果要显示的话就需要先构造出这部分数据,不显示就用下面这个sql就好

    select a.* from advertise a join (select advertise_id,sum(count) sm from advertise group by advertise_id order by sm desc limit 10) b on a.advertise_id=b.advertise_id where a.date BETWEEN 20170403 AND 20170420 order by a.date,a.count;

    Antwort
    0
  • ringa_lee

    ringa_lee2017-05-17 10:10:03

    SELECT s.date,s.advertise_id,s.count FROM advertise_stat s
    WHERE
        EXISTS (
            SELECT advertise_id FROM (SELECT advertise_id FROM advertise_stat GROUP BY advertise_id ORDER BY count DESC LIMIT 10) AS advertise_temp
            WHERE advertise_id = s.advertise_id
        )
    AND s.date BETWEEN 20170403 AND 20170420
    ORDER BY s.date ASC,s.count DESC

    应该是这样的吧

    Antwort
    0
  • StornierenAntwort