更正日期格式

时间:2017-09-21 16:31:23

标签: php mysql date

我有一个php表单,其中包含开始日期和结束日期的字段。我已经将行存储在我的mysql数据库中,我想在开始日期和结束日期范围内显示记录。我有一个名为tdate of datetime value的列。我的表单以mm / dd / yyyy显示开始和结束日期,但mysql不接受。

更新: -

$edate = $_POST['edate'] ?? '';
$sdate = $_POST['sdate'] ?? '';
$endDate = date('Y-m-d', strtotime($edate));
$startDate = date('Y-m-d', strtotime($sdate));
if(isset($_POST['submit'])){
    $sql = "SELECT * FROM admin_master_tbl ";
$sql .= "WHERE tdate <= '$endDate' AND ";
$sql .= "tdate >= '$startDate' ";
$result = mysqli_query($conn, $sql);
$output = mysqli_fetch_array($result);
print_r($output); } 

好的,现在它适用于我的表格!

2 个答案:

答案 0 :(得分:3)

使用预准备语句并将日期字符串转换为MySQL可用作日期的格式。这个答案是以MySQL为中心的,它使用STR_TO_DATE将您的mm/dd/yyyy字符串转换为日期。

$sql = "SELECT * FROM admin_master_tbl ";
$sql .= "WHERE tdate <= STR_TO_DATE(?, '%m/%d/%Y') ";
$sql .= " AND tdate >= STR_TO_DATE(?, '%m/%d/%Y')";
$stmt = $con->prepare($sql);
$stmt->bind_param("ss", $edate, $sdate);
$stmt->execute();
$stmt->close();

bind_param()的第一个参数,即"ss"告诉PHP我们将两个字符串参数绑定到查询。

STR_TO_DATE的替代方法是将PHP日期字符串转换为PHP格式的ISO格式。在这种情况下,您不需要STR_TO_DATE,但使用预准备语句仍然是个好主意。

答案 1 :(得分:0)

您无法直接从“mysqli_query”回显结果。你应该在“mysqli_query”之后使用这个波纹管代码。

$output = mysqli_fetch_array( $result, MYSQLI_ASSOC);
print_r( $output );