基于日期查询计算SQL行数

时间:2016-07-19 04:54:48

标签: php mysql sql

我正在构建一个非常简单的PHP应用程序,他们只想列出他们当前的订单(来自SQL数据库),并根据订单的截止日期进行一些调用。

我正在尝试计算表格中所有截止日期不到6天的所有订单...... 我正在挣扎!

我已经在表格中显示了所有订单,但我不知道如何根据截止日期来计算行数。

order_duedate采用日期格式。

有没有人有任何建议?

我很擅长从数据库中提取信息,所以这可能非常简单 - 这是我正在使用的代码:

<?php

ob_start();
define('DB_SERVER', 'localhost');
define('DB_USERNAME', 'aaa');
define('DB_PASSWORD', 'aaa');
define('DB_DATABASE', 'aaa');
$connection = mysql_connect(DB_SERVER, DB_USERNAME, DB_PASSWORD) or die(mysql_error());
$database = mysql_select_db(DB_DATABASE) or die(mysql_error());

// TABLE ROWS AS FOLLOWS
// order_no / order_client / order_duedate / order_status


$table_all = "SELECT * FROM orders";
$table_all_data = mysql_query($table_all);


// COUNT ORDERS THAT HAVE ORDER_DUEDATE < 6 DAYS FROM NOW


?>

<p>TOTAL OVERDUE ORDERS</p>
<p><?php echo $total_overdue ?></p>



<?php
// DISPLAY COMPLETE TABLE OF DATA
while($row = mysql_fetch_array($table_all_data)){ 
    // CHANGE FORMAT OF DATE
    $reformat_duedate = $row['order_duedate'];
    $phpdate = strtotime( $reformat_duedate );
    $newdate = date( 'd/m/Y', $phpdate );

?>

<tr>
    <td><a href=""><?php echo $row['order_no'] ?></a></td>
    <td class="alignleft"><?php echo $row['order_client'] ?></td>
    <td><span class="date open"><?php echo $newdate ?></span></td>
    <td class="alignleft"><?php echo $row['order_status'] ?></td>
    <td>2</td>
    <td><a href=""><i class="fa fa-pencil" aria-hidden="true"></i></a>&nbsp;&nbsp;&nbsp;<a href=""><i class="fa fa-times" aria-hidden="true"></i></a></td>
</tr>


<?php } 

mysql_close(); ?>

非常感谢你!

3 个答案:

答案 0 :(得分:1)

SELECT *
FROM orders
WHERE date_add(order_duedate, INTERVAL -6 DAY) < now()

答案 1 :(得分:1)

您可以尝试SELECT * FROM orders WHERE order_duedate <= NOW() + INTERVAL 6 DAY

答案 2 :(得分:0)

运行另一个查询:

select count(*) from orders where order_duedate < CURDATE() + INTERVAL 6 DAY;