我有一个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); }
好的,现在它适用于我的表格!
答案 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 );