MySQL CONVERT_TZ() 問題
在資料庫中處理時區時,特別是夏令時(DST) 時,至關重要確保準確的轉換。以下是有關 MySQL CONVERT_TZ() 函數的一些問題及其解決方案:
Q1。時區名稱的準確度
是的,您是對的。指定時區名稱(例如“美國/東部”)應自動考慮夏令時。由於 DST,CONVERT_TZ('00:00:00', 'UTC', 'US/EASTERN') 確實應該在 1 月 1 日和 7 月 1 日產生不同的結果。
第二季。更新時區表
MySQL 使用一組時區表來決定各個時區的目前偏移量。如果您沒有使用這些表的最新版本,CONVERT_TZ() 函數可能無法正常運作。您可以透過執行以下查詢來檢查時區表是否是最新的:
SELECT VERSION() FROM mysql.time_zone_name;
如果輸出顯示的版本號低於“2018h”,您應該透過執行以下命令來更新表以下命令:
mysql_tzinfo_to_sql /usr/share/zoneinfo/ | mysql -u root -p mysql
Q3。 CONVERT_TZ() 的「NULL」結果
您遇到的「NULL」結果可能表示時區表未正確安裝或初始化。要驗證這一點,請執行以下查詢:
SELECT COUNT(*) FROM mysql.time_zone;
如果結果為 0,則表示時區表為空。在這種情況下,您可以使用上述命令安裝它們。
替代解決方案
雖然 CONVERT_TZ() 通常是時區轉換的可靠解決方案,但還有一種無需時區表的替代方法。您可以儲存使用者與UTC 的時區偏移(以小時為單位),並使用以下查詢將UTC 時間轉換為使用者的本地時間:
SELECT UTC_TIMESTAMP() + INTERVAL user_timezone_offset_in_hours HOUR;
此方法不需要時區表,並且實現起來相對簡單.
以上是如何對 MySQL 的 CONVERT_TZ() 函數進行故障排除以實現準確的時區轉換?的詳細內容。更多資訊請關注PHP中文網其他相關文章!