输入开始日期和结束日期,并将日期插入到db中

时间:2012-03-29 08:26:46

标签: php mysql

是否有在php中运行的查询允许您在两个日期之间插入所有日期?

例如,输入03/20/2012和03/20/2013并使用两者之间的所有日期填充mysql?

我正在为一家航空公司制作一个票务系统,他们每天有来自20多个地点的13个航班,并且手动插入这些航班变得乏味。

我想插入日期以及每天的值

EG。

 FROM                TO              Date_From              Date_To
     Dar Es Salaam      Zanzibar         03/20/2012             03/21/2012
     Dar Es Salaam      Zanzibar         03/21/2012             03/22/2012

注意

我不想生成这个列表(我研究过的问题只回答了如何生成列表)我想要播放一个MySQL数据库

非常感谢任何帮助

3 个答案:

答案 0 :(得分:2)

您可以使用此功能生成日期数组

function dateRange( $first, $last, $step = '+1 day', $format = 'd/m/Y' ) {

    $dates = array();
    $current = strtotime( $first );
    $last = strtotime( $last );

    while( $current <= $last ) {

        $dates[] = date( $format, $current );
        $current = strtotime( $step, $current );
    }

    return $dates;
}

$dateRange = dateRange("03/20/2012", "03/20/2013);

然后在数组上使用iterato插入数据

$stmt = $dbh->prepare("INSERT INTO table (from, to, date_from, date_to) VALUES (:from, :to, :datefrom, :dateto)");
$stmt->bindParam(':from', "Dar Es Salaam");
$stmt->bindParam(':to', "zanzibar");
$stmt->bindParam(':from', $datefrom);
$stmt->bindParam(':to', $dateto);
for ($i = 0; $i < count($dateRange); $i++){
   $datefrom  = strototime($dateRange[$i]);
   $dateto  = strototime($dateRange[$i+1]);
   $stmt->execute();
}

答案 1 :(得分:0)

填充数据库的最简单方法是生成SQL插入查询列表。

因此,如果您可以生成执行类似insert into table (... , date_from, date_to, ... ) values ( ..., val1, val2, ...)之类的查询的列表,则可以运行这些查询并对表进行大量搜索。

答案 2 :(得分:0)

$int_date_from = strtotime($str_date_from); // Will be used often
$int_days = (strtotime($str_date_to) - $int_date_from); // Calculate difference in seconds
$int_days /= floor(60 * 60 * 24); // Seconds to days

$arr_values = array();
for($i = 0; $i < $int_days; $i++) {
    $str_new_date_from = date('m/d/Y', strtotime("+{$i} Days", $int_date_from));
    $str_new_date_to = date('m/d/Y', strtotime('+'.($i + 1).' Days', $int_date_from));

    $arr_values[] = "('{$str_from}', '{$str_to}', '{$str_new_date_from}', '{$str_date_to}')";
}

$str_values = implode(', ', $arr_values);

mysql_query("
INSERT INTO table
VALUES {$str_values}
");