
本文详细讲解如何将从 mysql 查询出的 `yyyy-mm-dd hh:mm:ss` 格式日期(如 `2022-01-31 00:00:00`)安全、准确地转换为 `mm/dd/yyyy`(如 `01/31/2022`)并在 html 表格中显示,适用于初学者,包含完整代码示例与关键注意事项。
在 PHP 中格式化数据库中的日期字段,核心思路是:先将数据库返回的字符串解析为时间戳,再用 date() 函数按需格式化输出。你当前的日期字段(如 DateReceived 和 DateLastEdited)在 MySQL 中通常为 DATETIME 类型,PHP 获取后是字符串(如 "2022-01-31 00:00:00"),不能直接用于 date() 函数——必须先通过 strtotime() 转为 Unix 时间戳。
但注意:原答案中使用的格式 "Y/d/m" 实际会输出 2022/31/01(年/日/月),不符合你要求的 01/31/2022(月/日/年)。正确格式应为 "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 表示四位数年份(如 2022)
将这段逻辑整合进你的循环中,替换原始 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 | |||||||
? 重要提示与最佳实践:
立即学习“PHP免费学习笔记(深入)”;
- ✅ 永远验证日期字段非空:strtotime() 遇到 NULL 或非法字符串(如 '0000-00-00 00:00:00')会返回 false,导致 date() 输出 1970/01/01 —— 这是常见陷阱。使用 !empty() 或 is_string() + 正则校验更稳妥。
- ✅ 推荐升级方案(MySQL 层格式化):若仅需展示,可在 SQL 中直接格式化,减少 PHP 处理负担:
SELECT ..., DATE_FORMAT(DateReceived, '%m/%d/%Y') AS DateReceivedFmt, ...
然后在 PHP 中直接使用 {$row['DateReceivedFmt']}。
- ⚠️ 避免 Y/d/m 等易混淆格式符;牢记:m=month, d=day, Y=4-digit year。
- ? 生产环境务必开启错误报告(error_reporting(E_ALL))并记录异常,便于调试日期解析失败问题。
掌握这一模式后,你可轻松扩展为 F j, Y(如 January 31, 2022)或 d-M-Y(31-Jan-2022)等任意格式——只需调整 date() 的第一个参数即可。











