0

我正在使用 php 的形式来捕获日期,将其转换为 unixtime,然后将其插入 mysql。问题是,当我尝试插入 2012 年 1 月 1 日时,插入的是 2011 年 12 月 31 日。这一定是一个简单的问题,但我可以使用一些帮助。

这是我的表单代码:

<select name="mo">
   <?php 
   $arrMo = array("January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December");
   foreach ($arrMo as $key => $value) {
       $option_val = intval($key) + 1;
    echo "<option value='" . $option_val . "'>" . $value . "</option>"; 
}

   ?>
   </select>  / 

   <select name="day">
   <?php 
   for ($b = 1; $b < 32; $b++) {
       echo "<option value='" . $b . "'>" . $b . "</option>\n";
   }
   ?>
   </select>  / 
   <select name="year">
   <?php $thisyear = date("Y");
   $thisyear = intval($thisyear);
   for ($c = 0; $c < 6; $c++) {
       $newval = $thisyear - intval($c);
       echo "<option value='" . $newval . "'>" . $newval . "</option>\n";
   }

   ?>
   </select>

然后我在php中改变它:

$timestamp =  $_POST['year'] . "-" .  $_POST['mo'] . "-" . $_POST['day'];
$timestamp = strtotime("Y-m-d H:i:s", $timestamp);//turn it into Unix time
$mysqldatetime = date("Y-m-d H:i:s", $timestamp);

然后我尝试将其插入数据库:

$q_location = "Insert into markers(MarkerID, lat, lng, street, neighborhood, date) values(" . $nextLocation . ", '" . $_POST['latitude'] . "', '" . $_POST['longitude'] . "', '" . addslashes($_POST['address_public']) . "', '" .   addslashes($_POST['neighborhood']) . "', FROM_UNIXTIME(" . $mysqldatetime . "))";

知道我做错了什么吗?

4

3 回答 3

0

在 SQL 查询中删除 FROM_UNIXTIME。如果你的日期格式已经是 Ymd H:i:s 你可以直接使用这个变量 $mysqldatetime。

否则,您需要将时间戳传递给 FROM_UNIXTIME() 函数。

编辑:

实际上你的时间戳是错误的:

$timestamp =  $_POST['year'] . "-" .  $_POST['mo'] . "-" . $_POST['day'];
$timestamp = strtotime("Y-m-d H:i:s", $timestamp);//turn it into Unix time
$mysqldatetime = date("Y-m-d H:i:s", $timestamp);

只需将其更改为:

$mysqldatetime = strtotime($_POST['year'] . "-" .  $_POST['mo'] . "-" . $_POST['day']);

不需要 $timestamp 行,您应该能够保持 SQL 查询不变。

于 2012-10-28T22:03:46.327 回答
0

day 看起来基于 0 的变化

$timestamp =  $_POST['year'] . "-" .  $_POST['mo'] . "-" . $_POST['day'];

$timestamp =  $_POST['year'] . "-" .  $_POST['mo'] . "-" . $_POST['day']-1;
于 2012-10-28T22:03:53.630 回答
0

好的,答案原来是......我在插入语句中缺少日期周围的引号。格。谢谢大家,为了帮助我!

于 2012-10-28T22:34:06.917 回答