× 說心事 政治時事 生活 運動 汽車 機車 自行車 相機 科技 理財 旅遊美食 娛樂 健康 美麗時尚 人際關係 文學故事 關於《思書》
吃喝玩樂 關於《思書》

Rails 時區好亂啊,通通轉成 UTC

紅寶鐵軌客
來關注...
關注:紅寶鐵軌客
關注有什麼好處?:當作者有新文章發佈時,「思書日報」就會匯總自動通知您,讓您更容易與作者互動。
x
紅寶鐵軌客
Rails 使用中,折磨中,享受中......
Victorian vintage round cut ruby engagement ring in 14k yellow gold 7mm center vs g h 984
    很久以前就是個「寫程式的」,其實,什麼程式都不熟⋯⋯
     
    就,這會一點點,那會一點點⋯⋯
作者最新發佈的文章:
  • Rails 如何檢查 URL 是否存在?
  • Rails 為什麼要使用 escape_javascript?
  • Rails 使用 Javascript Ajax 很簡單
作者最近參與的討論:
  • Rails 常見資安陷阱與解決方法
現在就加入《思書》,你就可以關注本作者了!
《思書》是一個每個人的寫作與論壇平台,特有的隱私管理,讓你寫作不再受限,討論更深入真實,而且免費。 趕快來試試!
還未加入《思書》? 現在就登錄! 已經加入《思書》── 登入
Rails 使用中,折磨中,享受中......
2017/11/06
63   0  

時間處理,或是一段時間的資料收集,可能是很多網路應用上必定要有的功能,但是寫程式時,尤其是當面對多時區時,真的要頭腦清晰,我倒是發現了一個好方法,在 Rails 中,有很多與時間相關的設定與使用方式,我也真的常會搞錯,所以這篇主要是自己做參考用的記錄用,但是應該也會對其他苦主有幫助。

在 Rails 中,預設時區是設定在 config/application.rb 中,預設時區的設定為 config.time_zone,以台北為例,預設時區為台北的話,就加一行 config.time_zone = “Taipei”,基本上,這是設定程式(不是資料庫)的基礎參考時區,這是一個很重要的設定與了解,我剛開始用 Rails 時,並沒有設定這,結果好像也相安無事,沒設定,就是一切以 UTC 為主,就是 +0,但是這樣使用有很大的問題,一旦你以後加上預設時區,你就慘了,因為,在 Rails 中,資料庫裡面的時間欄位,datetime,一定都是儲存 UTC 的時間,也就是說,它會根據你的程式預設時區來重新計算時間,例如,預設時區為台北 (UTC+8) 時區,這時存取資料庫,Rails 便會幫你自動轉換時區,也就是拿出來時 +8,存回去時 -8,你可以在 Log 中看到類似以下的換算:

irb(main):001:0> Blog.where( "created_at > ? and created_at <= ?", Time.now.beginning_of_day, Time.now.end_of_day )
=> SELECT * FROM "blogs" WHERE (created_at > '2017-03-30 16:00:00' and created_at <= '2017-03-31 15:59:59')

看起來簡單,這拿出來與存回去,在多時區開發中,常搞得我頭腦不清,我後還就發現一個好方法,就是:

通通轉成 UTC

很笨,但是真的很好用,反正電腦會算的,我們就用電腦,以下是用 Rails Console 的測試:

irb(main):001:0> Time.now
=> 2017-11-06 18:16:35 +0800
irb(main):002:0> Time.now.utc
=> 2017-11-06 10:16:43 UTC

可以看到,不同的時區,用個 .utc 就可以簡單的轉成 UTC,所以,不管使用者身在哪裡,他們的時區改變,在處理時都轉成 UTC,這對一般資料查詢是多此一舉,但是對自動執行的後台批次程式有很大的幫助,分享在這,希望對大家有幫助,我是留個紀錄,不要忘記了。

 時間比時間,日期比日期!

不要亂比,很容易錯的,而且錯誤都會很難找,久久才會出來一次,例如:

t1 = Time.new(2017, 9, 30, 18, 20, 0)
=> 2017-09-30 18:20:00 +0800
start_date
=> Fri, 01 Sep 2017
t1 > start_date.end_of_month
=> true
t1 > start_date.end_of_month.end_of_day
=> false
t1 > start_date.end_of_month.end_of_day.utc
=> false

這是用 Rails Console 驗證的,可以看到第 05 行,當日期比上時間時,完全不對了!

 

關於作者
很久以前就是個「寫程式的」,其實,什麼程式都不熟⋯⋯
 
就,這會一點點,那會一點點⋯⋯


標籤: 時區 x 1 utc x 1 time_zone x 1 rails x 27

分享:


參與討論!
x
現在就加入《思書》,馬上參與討論!
《思書》是一個每個人的寫作與論壇平台,特有的隱私管理,用筆名來區隔你討論內容,讓你的討論更深入,而且免費。 趕快來試試!
還未加入《思書》? 現在就登錄! 已經加入《思書》── 登入