1

私は列を持つa_ad_displayとしてMYSQLテーブル名に次のテーブルを持っています

╔═════════════╦═════════╦═════════╦═════════════════════╗
║ addisplayId ║ restId  ║ clicked ║     displaytime     ║
╠═════════════╬═════════╬═════════╬═════════════════════╣
║          1  ║  20707  ║      0  ║ 2013-02-28 10:50:55 ║
║          2  ║  20708  ║      1  ║ 2013-02-28 10:55:55 ║
║          3  ║  20711  ║      1  ║ 2013-03-01 12:50:55 ║
║          4  ║  20712  ║      1  ║ 2013-03-02 01:50:55 ║
║          5  ║  20707  ║      1  ║ 2013-03-03 10:50:55 ║
║          6  ║  20708  ║      1  ║ 2013-03-03 12:50:55 ║
║          7  ║  20707  ║      1  ║ 2013-03-04 09:50:55 ║
║          8  ║  20708  ║      1  ║ 2013-03-05 10:50:55 ║
║          9  ║  20708  ║      0  ║ 2013-03-06 11:50:55 ║
║         10  ║  20707  ║      0  ║ 2013-03-06 12:50:55 ║
╚═════════════╩═════════╩═════════╩═════════════════════╝

今、クリックした列で1の同時実行が最も高いrestIdをフェッチしたい

したがって、上記のレコードから、20708 の restId はクリックされた列の数が最も多く、3 です。このシナリオで restId を取得したいのですが、どうすればこれを行うことができるか教えてもらえますか?

4

1 に答える 1

1

これは最も簡単な答えですが、重複は処理されません。

SELECT  restID, SUM(clicked) totalClick
FROM    a_ad_display
GROUP   BY restID
ORDER   BY totalClick DESC
LIMIT   1

重複を保持するクエリは次のとおりです。

SELECT  restID, SUM(clicked) totalClick
FROM    a_ad_display
GROUP   BY restID
HAVING  SUM(clicked) = 
        (
            SELECT  SUM(clicked) totalClick
            FROM    a_ad_display
            GROUP   BY restID
            ORDER   BY totalClick DESC
            LIMIT   1
        )
于 2013-03-11T05:48:46.260 に答える