首頁 後端開發 php教程 在PHP和MySQL中與日期和時間合作

在PHP和MySQL中與日期和時間合作

Feb 28, 2025 am 09:22 AM

Working with Dates and Times in PHP and MySQL

在任何編程語言中處理日期和時間通常是一項簡單瑣碎的任務,直到需要支持時區。幸運的是,PHP擁有一套強大的日期/時間工具,可以幫助您處理各種時間相關問題:Unix時間戳、格式化日期以供人類閱讀、顯示帶有時區的日期、計算現在到下個月第二個星期二之間的時間差等等。本文將介紹PHP的時間函數(time()mktime()date())及其面向對像對應項的基礎知識,然後了解MySQL日期,並向您展示如何使它們與PHP完美配合。

主要收穫

  • 利用PHP強大的日期和時間函數,如time()mktime()date(),有效處理Unix時間戳和格式化日期。
  • 利用PHP的DateTimeDateTimeZone對象進行面向對象的日期和時間操作,包括處理不同的時區。
  • 將日期存儲在MySQL中作為Unix時間戳,以保持不同時區之間的一致性,並利用PHP的日期/時間函數進行轉換和格式化。
  • 將服務器的默認時區設置為PHP配置中的UTC,以簡化日期和時間管理並確保應用程序的一致性。

PHP日期和時間函數

本文的大部分內容將使用Unix時間,也稱為POSIX時間或紀元時間。時間表示為自1970年1月1日午夜UTC以來經過的秒數。如果您對Unix時間的完整歷史感興趣,請查看維基百科上的Unix時間文章。 UTC(協調世界時),也稱為GMT,有時也稱為Zulu時間,是0度經線的時間。世界上所有其他時區都表示為相對於此時間的正或負偏移量。使用UTC和Unix時間處理時間,在需要處理時區時會讓您的生活更輕鬆。稍後我會詳細介紹這一點,但現在讓我們忽略時區問題,並查看一些時間函數。

獲取當前Unix時間

time()不接受任何參數,並返回自Unix紀元以來的秒數。為了說明這一點,我將使用PHP交互式CLI shell。

sean@beerhaus:~$ php -a
php > print time();
1324402770
登入後複製
登入後複製
登入後複製
登入後複製

如果您需要Unix時間的數組表示,請使用getdate()函數。它接受一個可選的Unix時間戳參數,但如果沒有提供,則默認為time()的值。

php > $unixTime = time();
php > print_r(getdate($unixTime));
Array
(
    [seconds] => 48
    [minutes] => 54
    [hours] => 12
    [mday] => 20
    [wday] => 2
    [mon] => 12
    [year] => 2011
    [yday] => 353
    [weekday] => Tuesday
    [month] => December
    [0] => 1324403688
)
登入後複製
登入後複製
登入後複製
登入後複製

格式化Unix時間

Unix時間可以輕鬆格式化為人類希望閱讀的任何字符串。 date()用於將Unix時間戳格式化為人類可讀的字符串,並接受一個格式化參數和一個可選的時間參數。如果沒有提供可選的時間戳,則使用time()的值。

sean@beerhaus:~$ php -a
php > print time();
1324402770
登入後複製
登入後複製
登入後複製
登入後複製

“r”格式化字符串返回由RFC 2822指定的格式化時間。當然,您可以使用其他說明符來定義您自己的自定義格式。

php > $unixTime = time();
php > print_r(getdate($unixTime));
Array
(
    [seconds] => 48
    [minutes] => 54
    [hours] => 12
    [mday] => 20
    [wday] => 2
    [mon] => 12
    [year] => 2011
    [yday] => 353
    [weekday] => Tuesday
    [month] => December
    [0] => 1324403688
)
登入後複製
登入後複製
登入後複製
登入後複製

有關可接受的格式化字符的完整列表,請參閱PHP文檔中date()的頁面。但是,當與mktime()strtotime()函數結合使用時,該函數變得更有用,正如您將在接下來的示例中看到的。

根據給定時間創建Unix時間

mktime()用於根據與日期的每個部分相對應的值列表(秒、分、小時、年等)創建Unix時間戳。它接受許多整數參數,以以下順序設置日期的每個部分:

php > print date("r", $unixTime);
Tue, 20 Dec 2011 12:54:48 -0500
登入後複製
登入後複製
登入後複製

如果啟用了夏令時,則將isDST設置為1;如果沒有啟用,則設置為0;如果未知,則設置為-1(默認值)。

php > print date("m/d/y h:i:s a", $unixTime);
12/20/11 12:54:48 pm
php > print date("m/d/y h:i:s a");
12/20/11 01:12:11 pm
php > print date("jS of F Y", $unixTime);
20th of December 2011
登入後複製
登入後複製
登入後複製

您可以看到,在處理使用用戶自定義日期範圍的數據庫查詢時,mktime()非常有用。例如,如果您在MySQL中將時間戳存儲為整數(Unix時間)(預示著任何人嗎?),則很容易設置一個常見的年至今查詢範圍。

<code>mktime(hour, minute, second, month, day, year, isDST)</code>
登入後複製
登入後複製
登入後複製

將英文日期解析為Unix時間

幾乎神奇的函數strtotime()將日期/時間格式的字符串作為其第一個參數,以及用作轉換基礎的Unix時間戳。請參閱文檔以了解可接受的日期格式。

php > print date("r", mktime(12, 0, 0, 1, 20, 1987));
Tue, 20 Jan 1987 12:00:00 -0500
php > print date("r", mktime(0, 0, 0, date("n"), date("j"), date("Y")));
Tue, 20 Dec 2011 00:00:00 -0500
php > print date("r", mktime(23, 59, 59, date("n"), date("j"), date("Y")));
Tue, 20 Dec 2011 23:59:59 -0500
登入後複製
登入後複製

PHP的DateTime和DateTimeZone對象

PHP的DateTime對像是處理日期和時區的面向對象方法。構造方法接受時間的字符串表示,非常類似於上面的strtotime(),有些人可能會覺得這更容易使用。如果沒有提供參數,則默認值為“now”。

<?php $startTime = mktime(0, 0, 0, 1, 1, date("y"));
$endTime   = mktime(0, 0, 0, date("m"), date("d"), date("y"));
登入後複製
登入後複製

DateTimeformat()方法與上面的date()函數的工作方式相同,並接受所有相同的格式化字符。 DateTime對像還帶有一些有用的常量,可以將其饋送到format()方法。

php > print strtotime("now");
1324407707
php > print date("r", strtotime("now"));
Tue, 20 Dec 2011 14:01:51 -0500
php > print strtotime("+1 week");
1325012569
php > print date("r", strtotime("+1 week"));
Tue, 27 Dec 2011 14:03:03 -0500
php > print date("r", strtotime("next month"));
Fri, 20 Jan 2012 14:04:20 -0500
php > print date("r", strtotime("next month", mktime(0, 0, 0)));
Fri, 20 Jan 2012 00:00:00 -0500
php > print date("r", strtotime("next month", mktime(0, 0, 0, 1, 31)));
Thu, 03 Mar 2011 00:00:00 -0500
登入後複製

可以在DateTime文檔頁面上找到完整的常量列表。由於我們很快就會處理時區,讓我們為PHP提供一個默認時區。在您的php.ini配置文件(我有一個用於CLI,一個用於Apache)中,找到如下所示的部分:

php > $dt = new DateTime("now"); 
php > print $dt->format("r");
Tue, 20 Dec 2011 16:28:32 -0500
php > $dt = new DateTime("December 31 1999 12:12:12 EST");
php > print $dt->format("r");
Fri, 31 Dec 1999 12:12:12 -0500
登入後複製

當沒有為date.timezone賦予值時,PHP將盡力確定在服務器上設置的系統時區。您可以使用date_default_timezone_get()檢查PHP正在使用哪個值。

sean@beerhaus:~$ php -a
php > print time();
1324402770
登入後複製
登入後複製
登入後複製
登入後複製

讓我們將服務器的時區設置為UTC時間(date.timezone = UTC)並保存配置文件。您必須重新啟動Apache或CLI shell才能查看更改。 PHP DateTime對象包括一個內部DateTimeZone類實例來跟踪時區。當您創建DateTime的新實例時,內部DateTimeZone應設置為在php.ini中提供的默認值。

php > $unixTime = time();
php > print_r(getdate($unixTime));
Array
(
    [seconds] => 48
    [minutes] => 54
    [hours] => 12
    [mday] => 20
    [wday] => 2
    [mon] => 12
    [year] => 2011
    [yday] => 353
    [weekday] => Tuesday
    [month] => December
    [0] => 1324403688
)
登入後複製
登入後複製
登入後複製
登入後複製

可以在時區文檔頁面上找到可接受的時區名稱的完整列表。您現在可以看到當兩個DateTime對像被賦予不同的時區時,時間差異。例如,這是一個將UTC轉換為America/New_York(EST)時間的示例。

php > print date("r", $unixTime);
Tue, 20 Dec 2011 12:54:48 -0500
登入後複製
登入後複製
登入後複製

請注意12月份的-0500偏移量。如果您將時間值更改為夏季日期,例如7月1日,您會發現它知道夏令時(EDT)。

php > print date("m/d/y h:i:s a", $unixTime);
12/20/11 12:54:48 pm
php > print date("m/d/y h:i:s a");
12/20/11 01:12:11 pm
php > print date("jS of F Y", $unixTime);
20th of December 2011
登入後複製
登入後複製
登入後複製

將日期與MySQL和PHP一起使用

如果您在任何級別使用過MySQL,您可能已經註意到開箱即用的DATETIME類型。它看起來和聞起來像一個日期,如果您說它是一個日期,那麼您是對的。但是,一旦您將其從MySQL中SELECT到PHP中,您實際上擁有的只是一個看起來像日期的字符串。它沒有時區意識,並且在人類需要查看它之前就已經格式化好供人類使用了。 是的,我知道MySQL有很多日期格式化函數,但我們也已經在使用PHP了,正如您所看到的,PHP在處理日期格式方面非常出色。為什麼我們還要從數據庫中直接格式化它呢?我們可能需要應用一些不同的轉換和格式。最好只在人類即將看到日期時才格式化日期。

<code>mktime(hour, minute, second, month, day, year, isDST)</code>
登入後複製
登入後複製
登入後複製

運行這個簡單的腳本,您可以看到您從DATETIME字段獲得的只是一個格式化的字符串,沒有時區信息。

php > print date("r", mktime(12, 0, 0, 1, 20, 1987));
Tue, 20 Jan 1987 12:00:00 -0500
php > print date("r", mktime(0, 0, 0, date("n"), date("j"), date("Y")));
Tue, 20 Dec 2011 00:00:00 -0500
php > print date("r", mktime(23, 59, 59, date("n"), date("j"), date("Y")));
Tue, 20 Dec 2011 23:59:59 -0500
登入後複製
登入後複製

DATETIME值是運行MySQL的服務器的本地時間,無論該服務器的時區是什麼。如果您所做的所有事情都只涉及一個時區中的一個服務器,那麼DATETIME可能適合您的大部分需求,而且我非常羨慕您。那麼,如何使用PHP和MySQL處理日期和時區呢?將日期存儲為Unix時間戳。您已經知道Unix時間是自1970年1月1日UTC以來的秒數,因此這為您提供了一個恆定的時區,並且您可能已經註意到PHP的許多日期/時間函數都是基於Unix時間戳的。在使用MySQL時,我通常創建將日期存儲為INTEGER UNSIGNED的表列。插入日期時,您可以使用PHP的time()或MySQL的UNIX_TIMESTAMP()

<?php $startTime = mktime(0, 0, 0, 1, 1, date("y"));
$endTime   = mktime(0, 0, 0, date("m"), date("d"), date("y"));
登入後複製
登入後複製

如果您希望MySQL格式化日期,您可以這樣做。但是時間將位於運行MySQL的服務器的時區中,我建議您在到達Web應用程序的模板/視圖級別並準備好讓人眼看到它之前,不要進行任何類型的格式化。

sean@beerhaus:~$ php -a
php > print time();
1324402770
登入後複製
登入後複製
登入後複製
登入後複製

在任何跨越時區的應用程序中,您通常都會有一個表來跟踪用戶的自定義時區設置,然後將其讀入$_SESSION值。假設您有一個如下所示的會話條目:

php > $unixTime = time();
php > print_r(getdate($unixTime));
Array
(
    [seconds] => 48
    [minutes] => 54
    [hours] => 12
    [mday] => 20
    [wday] => 2
    [mon] => 12
    [year] => 2011
    [yday] => 353
    [weekday] => Tuesday
    [month] => December
    [0] => 1324403688
)
登入後複製
登入後複製
登入後複製
登入後複製

您可以輕鬆地將存儲的Unix時間(以UTC為單位)轉換為特定用戶的時區中的任何日期。

php > print date("r", $unixTime);
Tue, 20 Dec 2011 12:54:48 -0500
登入後複製
登入後複製
登入後複製

這將導致日期“Mon, 16 Jan 2012 12:03:49 -0600”。 -0600告訴您它比UTC落後6小時,UTC的偏移量為0。如果我們將時區設置為America/Los_Angeles,則生成的日期將是:

php > print date("m/d/y h:i:s a", $unixTime);
12/20/11 12:54:48 pm
php > print date("m/d/y h:i:s a");
12/20/11 01:12:11 pm
php > print date("jS of F Y", $unixTime);
20th of December 2011
登入後複製
登入後複製
登入後複製

而America/New_York將產生:

<code>mktime(hour, minute, second, month, day, year, isDST)</code>
登入後複製
登入後複製
登入後複製

總結

處理日期和時區是許多程序員日常生活中的一部分,但是當您可以使用PHP強大且易於使用的日期庫時,無需擔心。您已經了解瞭如何獲取Unix時間戳、如何將日期格式化為任何可以想像的格式、如何將日期的英文表示解析為時間戳、如何將一段時間添加到時間戳以及如何在時區之間進行轉換。如果本文有兩個主要要點,那就是1)堅持使用Unix時間,以及2)在使用PHP和MySQL時,堅持使用UTC作為所有日期的基礎時區。基於UTC的所有時間的想法不僅適用於PHP和MySQL;它在任何語言中都被認為是最佳實踐。如果您發現自己正在使用其他語言工作,那麼您很有可能會對自己說:“該死的,他們為什麼不能像PHP那樣做?”

圖片來自Yakobchuk Vasyl / Shutterstock

(此處應添加關於在PHP中處理日期和時間的常見問題的FAQ部分,類似於輸入文本中的FAQ部分。 由於篇幅限制,我沒有在此處添加。)

以上是在PHP和MySQL中與日期和時間合作的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1658
14
CakePHP 教程
1415
52
Laravel 教程
1309
25
PHP教程
1257
29
C# 教程
1231
24
會話如何劫持工作,如何在PHP中減輕它? 會話如何劫持工作,如何在PHP中減輕它? Apr 06, 2025 am 12:02 AM

會話劫持可以通過以下步驟實現:1.獲取會話ID,2.使用會話ID,3.保持會話活躍。在PHP中防範會話劫持的方法包括:1.使用session_regenerate_id()函數重新生成會話ID,2.通過數據庫存儲會話數據,3.確保所有會話數據通過HTTPS傳輸。

說明PHP中的不同錯誤類型(注意,警告,致命錯誤,解析錯誤)。 說明PHP中的不同錯誤類型(注意,警告,致命錯誤,解析錯誤)。 Apr 08, 2025 am 12:03 AM

PHP中有四種主要錯誤類型:1.Notice:最輕微,不會中斷程序,如訪問未定義變量;2.Warning:比Notice嚴重,不會終止程序,如包含不存在文件;3.FatalError:最嚴重,會終止程序,如調用不存在函數;4.ParseError:語法錯誤,會阻止程序執行,如忘記添加結束標籤。

PHP和Python:比較兩種流行的編程語言 PHP和Python:比較兩種流行的編程語言 Apr 14, 2025 am 12:13 AM

PHP和Python各有優勢,選擇依據項目需求。 1.PHP適合web開發,尤其快速開發和維護網站。 2.Python適用於數據科學、機器學習和人工智能,語法簡潔,適合初學者。

什麼是HTTP請求方法(獲取,發布,放置,刪除等),何時應該使用? 什麼是HTTP請求方法(獲取,發布,放置,刪除等),何時應該使用? Apr 09, 2025 am 12:09 AM

HTTP請求方法包括GET、POST、PUT和DELETE,分別用於獲取、提交、更新和刪除資源。 1.GET方法用於獲取資源,適用於讀取操作。 2.POST方法用於提交數據,常用於創建新資源。 3.PUT方法用於更新資源,適用於完整更新。 4.DELETE方法用於刪除資源,適用於刪除操作。

說明PHP中的安全密碼散列(例如,password_hash,password_verify)。為什麼不使用MD5或SHA1? 說明PHP中的安全密碼散列(例如,password_hash,password_verify)。為什麼不使用MD5或SHA1? Apr 17, 2025 am 12:06 AM

在PHP中,應使用password_hash和password_verify函數實現安全的密碼哈希處理,不應使用MD5或SHA1。1)password_hash生成包含鹽值的哈希,增強安全性。 2)password_verify驗證密碼,通過比較哈希值確保安全。 3)MD5和SHA1易受攻擊且缺乏鹽值,不適合現代密碼安全。

PHP:網絡開發的關鍵語言 PHP:網絡開發的關鍵語言 Apr 13, 2025 am 12:08 AM

PHP是一種廣泛應用於服務器端的腳本語言,特別適合web開發。 1.PHP可以嵌入HTML,處理HTTP請求和響應,支持多種數據庫。 2.PHP用於生成動態網頁內容,處理表單數據,訪問數據庫等,具有強大的社區支持和開源資源。 3.PHP是解釋型語言,執行過程包括詞法分析、語法分析、編譯和執行。 4.PHP可以與MySQL結合用於用戶註冊系統等高級應用。 5.調試PHP時,可使用error_reporting()和var_dump()等函數。 6.優化PHP代碼可通過緩存機制、優化數據庫查詢和使用內置函數。 7

解釋PHP 7.4中引入的箭頭功能(短閉合)。 解釋PHP 7.4中引入的箭頭功能(短閉合)。 Apr 06, 2025 am 12:01 AM

箭頭函數在PHP7.4中引入,是短閉包的簡化形式。 1)它們使用=>運算符定義,省略function和use關鍵字。 2)箭頭函數自動捕獲當前作用域變量,無需use關鍵字。 3)它們常用於回調函數和短小計算,提高代碼簡潔性和可讀性。

PHP行動:現實世界中的示例和應用程序 PHP行動:現實世界中的示例和應用程序 Apr 14, 2025 am 12:19 AM

PHP在電子商務、內容管理系統和API開發中廣泛應用。 1)電子商務:用於購物車功能和支付處理。 2)內容管理系統:用於動態內容生成和用戶管理。 3)API開發:用於RESTfulAPI開發和API安全性。通過性能優化和最佳實踐,PHP應用的效率和可維護性得以提升。

See all articles