
本文详细讲解如何将从 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 行即可。以下是优化后的完整代码片段(含错误防护建议):
<?php
require '../../db_php/dbconnection.php';
$sql = "SELECT * FROM
Tickets
LEFT JOIN Clients ON Tickets.CustomerNumber = Clients.CustomerNumber
JOIN Contacts ON Contacts.ContactID = Clients.CustomerNumber
JOIN Equipment ON Equipment.ContactID = Clients.CustomerNumber
WHERE Equipment.PRINT = '-1'
AND Contacts.DispatchContact = '-1'
AND TicketStatus = 'Active'
AND TicketSubStatus != 'CUSTOMER PICKUP'
AND TaskSubType != 'ON-SITE'";
$result = $conn->query($sql);
echo "<table border='1'>";
echo "<tr>
<td>Ticket Type</td>
<td>Ticket Number</td>
<td>Date Received</td>
<td>Last Edited</td>
<td>Last Name</td>
<td>Followup By</td>
<td>Sub Status</td>
<td>Repair Type</td>
</tr>";
if ($result && $result->num_rows > 0) {
while ($row = $result->fetch_assoc()) {
// 安全处理日期字段:检查是否为空或无效
$dateReceived = !empty($row['DateReceived']) ? date("m/d/Y", strtotime($row['DateReceived'])) : '—';
$dateLastEdited = !empty($row['DateLastEdited']) ? date("m/d/Y", strtotime($row['DateLastEdited'])) : '—';
echo "<tr>
<td>{$row['TaskSubType']}</td>
<td>{$row['TicketNumber']}</td>
<td>{$dateReceived}</td>
<td>{$dateLastEdited}</td>
<td>{$row['ContactLast']}</td>
<td>{$row['FollowupBy']}</td>
<td>{$row['TicketSubStatus']}</td>
<td>{$row['ItemType']}</td>
</tr>";
}
} else {
echo "<tr><td colspan='8'>0 records</td></tr>";
}
echo "</table>";
$conn->close();
?>? 重要提示与最佳实践:
立即学习“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() 的第一个参数即可。











