本文详细讲解如何将从 mysql 查询出的 `yyyy-mm-dd hh:mm:ss` 格式日期(如 `2025-01-31 00:00:00`)安全、准确地转换为 `mm/dd/yyyy`(如 `01/31/2025`)并在 html 表格中显示,适用于初学者,包含完整代码示例与关键注意事项。
在 PHP 中格式化数据库中的日期字段,核心思路是:先将数据库返回的字符串解析为时间戳,再用 date() 函数按需格式化输出。你当前的日期字段(如 DateReceived 和 DateLastEdited)在 MySQL 中通常为 DATETIME 类型,PHP 获取后是字符串(如 "2025-01-31 00:00:00"),不能直接用于 date() 函数——必须先通过 strtotime() 转为 Unix 时间戳。
但注意:原答案中使用的格式 "Y/d/m" 实际会输出 2025/31/01(年/日/月),不符合你要求的 01/31/2025(月/日/年)。正确格式应为 "m/d/Y":
$dr = date("m/d/Y", strtotime($row['DateReceived']));
$dl = date("m/d/Y", strtotime($row['DateLastEdited']));✅ m 表示带前导零的月份(01–12)
✅ d 表示带前导零的日期(01–31)
✅ Y 表示四位数年份(如 2025)
将这段逻辑整合进你的循环中,替换原始 echo 行即可。以下是优化后的完整代码片段(含错误防护建议):
query($sql); echo "
| Ticket Type | Ticket Number | Date Received | Last Edited | Last Name | Followup By | Sub Status | Repair Type |
| {$row['TaskSubType']} | {$row['TicketNumber']} | {$dateReceived} | {$dateLastEdited} | {$row['ContactLast']} | {$row['FollowupBy']} | {$row['TicketSubStatus']} | {$row['ItemType']} |
| 0 records | |||||||
? 重要提示与最佳实践:
SELECT ..., DATE_FORMAT(DateReceived, '%m/%d/%Y') AS DateReceivedFmt, ...
然后在 PHP 中直接使用 {$row['DateReceivedFmt']}。
掌握这一模式后,你可轻松扩展为 F j, Y(如 January 31, 2025)或 d-M-Y(31-Jan-2025)等任意格式——只需调整 date() 的第一个参数即可。