2012-04-09 5 views
2

date列がNULLの行を、その行の直前および直近のidの日付の平均をとって更新しようとしています。以下のデータで欠落している日付を平均化するためのMySQL

、それはMySQLの文はこれを実現するだろうか2011-10-19

するID 26で行を更新しますか?


追加メモ:

データは次のようになります。

id  date   title 
-------------------------------------------- 
12  2011-09-01  Example One 
23  2011-10-02  Example Two 
26  NULL   Example Three 
27  2011-11-05  Example Four 
29  2012-01-05  Example Five 
37  NULL   Example Six 
38  2012-02-03  Example Seven 
-------------------------------------------- 

私は手順を使用しないことを好むだろう。

これまでのところ、私が持っている

...

UPDATE `table` 
    SET `date`= 
     (AVG(
       (SELECT `date` FROM `table` WHERE `id`< ID_OF_PARENT_QUERY AND `date` IS NOT NULL LIMIT 1), 
       (SELECT `date` FROM `table` WHERE `id`> ID_OF_PARENT_QUERY AND `date` IS NOT NULL LIMIT 1) 
     )) 

    WHERE `date` IS NULL 
+0

あなたは1の連続した 'NULL'値以上のものを持っていることはできますか?そうであれば、どのように進めますか? –

+0

@MostyMostacho - はい。私は 'date'値が設定されているところで一番近い行(一意のIDによる)を探したいと思います。 – DesignerGuy

答えて

4
UPDATE tableX AS t 
    JOIN tableX AS next 
    ON next.id = 
     (SELECT MIN(n.id) 
     FROM tableX AS n 
     WHERE n.id > t.id 
      AND n.dateX IS NOT NULL 
     ) 
    JOIN tableX AS prev 
    ON prev.id = 
     (SELECT MAX(p.id) 
     FROM tableX AS p 
     WHERE p.id < t.id 
      AND p.dateX IS NOT NULL 
     ) 
SET t.dateX = prev.dateX + INTERVAL (DATEDIFF(next.dateX, prev.dateX)/2) DAY 
WHERE t.dateX IS NULL 
+1

+1完璧な解決策 – diEcho

関連する問題