2017-08-13 16 views
0

の時間を守る、私は次の表を持っている:のPostgres、更新TIMESTAMP現在の日付までが、私のPostgresデータベースでは日

SELECT start_at, end_at FROM schedules; 

+---------------------+---------------------+ 
| start_at   | end_at    | 
|---------------------+---------------------| 
| 2016-09-05 16:30:00 | 2016-09-05 17:30:00 | 
| 2016-09-05 17:30:00 | 2016-09-05 18:30:00 | 
| 2017-08-13 03:00:00 | 2017-08-13 07:00:00 | 
| 2017-08-13 03:00:00 | 2017-08-13 07:00:00 | 
| 2017-08-13 18:42:26 | 2017-08-13 21:30:46 | 
| 2017-08-10 00:00:00 | 2017-08-10 03:30:00 | 
| 2017-08-09 18:00:00 | 2017-08-10 03:00:00 | 
| 2017-08-06 23:00:00 | 2017-08-07 03:00:00 | 
| 2017-08-07 01:00:00 | 2017-08-07 03:48:20 | 
| 2017-08-07 01:00:00 | 2017-08-07 03:48:20 | 
| 2017-08-07 18:05:00 | 2017-08-07 20:53:20 | 
| 2017-08-07 14:00:00 | 2017-08-08 01:00:00 | 
| 2017-08-07 18:00:00 | 2017-08-07 20:48:20 | 
| 2017-08-08 08:00:00 | 2017-08-09 00:00:00 | 
| 2017-08-09 21:30:00 | 2017-08-10 00:18:20 | 
| 2017-08-13 03:53:26 | 2017-08-13 06:41:46 | 
+---------------------+---------------------+ 

は、私はまた、ID列があると、私は何をしたいのアップデートすべて開始時刻と終了時刻を今日(現在)にするには、これを達成する最も効率的なSQLは何ですか?私のテーブルには何百万もの行があります。算術行にアクセスに比べて高速である

update schedules 
    set start_at = current_date + start_at::time 
     , end_at = current_date + end_at::time 
    WHERE start_at::date <> current_date 
     or end_at::date <> current_date; 

:私は考えることができる

答えて

1

最高のはこれです。 すべての行を更新する必要がない場合は、where句を使用すると効率が向上します。アップデートは高価です。