「能在4小時或3天」 - 它不能4 HOUR
或3 DAY
?
您是否必須擔心無效單位甚至惡意(用戶)輸入?
您可以測試給定的字符串,並將單位「轉換」爲MySQL可以理解的內容。
<?php
$pattern = '!^(\d+) (.+)$!';
$units = array(
'days'=>'DAY',
'hours'=>'HOUR',
'minutes'=>'MINUTE'
);
foreach(array('14 days', '7 hours', '11 hours', '1 or 1=1') as $userinput) {
echo "\n", $userinput, ': ';
if (!preg_match($pattern, $userinput, $m) || !isset($units[$m[2]])) {
echo "error, cause: ...\n";
continue;
}
$sql = sprintf(' ...
WHERE
`table1`.`DateField` >= Now() - INTERVAL %d %s', $m[1], $units[$m[2]]
);
echo $sql, "\n";
}
打印
14 days: ...
WHERE
`table1`.`DateField` >= Now() - INTERVAL 14 DAY
7 hours: ...
WHERE
`table1`.`DateField` >= Now() - INTERVAL 7 HOUR
11 hours: ...
WHERE
`table1`.`DateField` >= Now() - INTERVAL 11 HOUR
1 or 1=1: error, cause: ...