1

我有这样的脚本:

mysql_connect('localhost', 'xxx', 'xxx');
mysql_select_db('xxx');

$sql = "SELECT * FROM rl_cronjobs";
$sql = mysql_query($sql);
$row = mysql_fetch_array($sql);

$sunday = $row['next_sunday'];
$today = date('Y-m-d');


if($sunday == $today){
    $sql = "DELETE * FROM xxx WHERE stala != 1";
    $sql = mysql_query($sql);
    echo $nextsunday;
    $nextsunday = strtotime("next Sunday");
    $nextsunday = date('Y-m-d', $nextsunday);   
    $sql = "UPDATE xxx SET next_sunday = $nextsunday";
    $sql = mysql_query($sql) or die (mysql_error());
    echo $nextsunday;
}

在 MySQL 中,它的值是: 1984 我需要它是下周日的正常日期

MySQL 表行的类型是 varchar,因为当我设置 tu date 时它不会更新。有什么帮助吗?

4

2 回答 2

1

看起来您缺少一些引号"'更新查询。你可能打算写:

$sql = "UPDATE xxx SET next_sunday = '$nextsunday'";

旁注:这些myslq_*函数已弃用,您不应再在新代码中使用它们。

于 2012-12-10T15:33:14.680 回答
1

不要将日期存储在 varchar 字段中。Mysql 具有用于此类事物的日期、日期时间和时间戳字段,并且使用它们打开了一个新的可能性世界。例如,您的“下周日”计算可以简单地完成:

UPDATE xxx SET next_sunday = NOW() + INTERVAL (8 - DAYOFWEEK(NOW())) DAY

无需涉及 PHP 时间函数。请注意,此特定函数将始终选择真正的下周日,因此如果您在周日运行此代码,您将获得下周的周日,而不是“今天”,例如:

'2012-12-08' (Saturday) -> '2012-12-09'
'2012-12-09' (Sunday)   -> '2012-12-16'
'2012-12-10' (Monday)   -> '2012-12-16'

同样,请注意,您正在尝试$nextsunday在定义之前回显。

于 2012-12-10T15:55:57.833 回答