MySQL查询获取营业时间和营业时间

时间:2019-03-30 08:24:36

标签: php mysql sql sql-query-store

我确实有开店,但是当我要打印关店时,查询将开店打印为关店。我的目标是进行相同的查询以打印开店和关店,因为现在我有两个不同的查询。

对我来说困难的是,餐厅每天可能营业两次。例如,餐厅,开放时间为星期一的上午10点至星期二03上午,星期二的上午10点至星期三03上午。

我尝试进行CASE WHEN查询,但问题是它无法获得带有打印状态的餐厅ID。

我的有两个插入餐厅的营业时间表注意,餐厅ID是餐厅表的外键。

 id,restaurantID,openday,opentime,closeday,closetime
 1,15,Monday,10:00:00,Tuesday,03:00:00
 2,15,Tuesday,10:00:00,Wednesday,03:00:00
 3,24,Monday,10:00:00,Tuesday,03:00:00
 4,24,Tuesday,10:00:00,Wednesday,03:00:00
 5,24,Wednesday,10:00:00,Thursday,04:00:00
 6,24,Thursday,10:00:00,Friday,02:00:00
 7,24,Friday,10:00:00,Saturday,01:00:00
 8,24,Saturday,11:00:00,Sunday,01:00:00
 9,24,Sunday,11:00:00,Monday,02:00:00

下面的第一个查询可完美打印开餐厅。 我如何获得封闭的餐厅?

查询开放餐厅的查询

        $stmt = $pdo->prepare("SELECT * FROM                         
                    business_hour 
                        INNER JOIN restaurant
                           ON business_hour.restaurantID = 
                            restaurant.id   
                    WHERE         
                     (closeday = '$today' AND closetime >= 
                      '$timeNow')  
                       OR
                     (openday = '$today' AND opentime <= 
                             '$timeNow')
                      ");  

        $stmt->execute();
        $i=0;
        while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
            echo $row['ravintolaID'].' '.'OPEN'.'  '.$row['openday'].' '.$row['opentime'].' --'.$row['closeday'].' '.$row['closetime'].' '.'<br>';

            $i++;   

        }

我尝试了此查询

用于检查已关闭餐厅的查询

  $stmt = $pdo->prepare("SELECT * FROM business_hour 
    INNER JOIN restaurant
   ON business_hour.restaurantID = restaurant.id    
    WHERE         
      (closeday = '$today' AND closetime < '$timeNow')  
           OR
       (openday = '$today' AND opentime > '$timeNow')
     ");    
    $stmt->execute();
        $i=0;
        while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
            echo $row['ravintolaID'].' '.'CLOSED'.' open at '.$row['openday'].' '.$row['opentime'].' --  '.$row['closeday'].' '.$row['closetime'].' '.'<br>';

            $i++;   

        }

我希望输出显示我只有一次关闭和打开餐厅。

当前日期为星期一,时间为 7am

输出

  24 OPEN Sunday 10:00:00 --Monday 08:00:00 
  15 CLOSED open at Monday 10:00:00 -- Tuesday 03:00:00 
  15 CLOSED open at Sunday 10:00:00 -- Monday 03:00:00 
  24 CLOSED open at Monday 10:00:00 -- Tuesday 03:00:00

0 个答案:

没有答案