将天数转换为相对于php天数的周数

时间:2014-01-02 06:36:31

标签: php mysql codeigniter

我有一个过滤器,它从日期过滤器基础上的数据库中获取数据,该过滤器查找两个日期之间的数据。例如从= 2013-12-15,到= 2013-12-20等,并返回我的resutl,其中包含我所需数据的日期。

现在我想如果用户选择的日期大于20天,例如从日期过滤器中选择的25天或超过1个月,可能会导致最多5个月,那么它应该转换为WEEKS格式并且它会返回数据在周基数上显示数据与周数。

<?php $date_from = 2012-12-01; $to_date = 2013-12-31;  ?>
像上面一样,我有一个月或四个星期。现在我想在周基数上显示数据,因为我在上述两个日期之间有超过20天的差异。

我在Google区域图表中应用此功能。现在我想在几周内显示数据而不是单日期基数。

我需要php,mysql中的解决方案。

我的代码

这是我的控制器功能,它获取发布日期值

public function get_sales_graph(){

      if($this->input->post()){

        $type = $this->input->post('type');  
        $get_date = str_replace("/", "-", $this->input->post('chosen_from_date'));
        $get_date = DateTime::createFromFormat('m-d-Y', $get_date);
        $from_date = $get_date->format('Y-m-d');

        $get_to_date = str_replace("/", "-", $this->input->post('chosen_to_date'));
        $get_to_date = DateTime::createFromFormat('m-d-Y', $get_to_date);
        $to_date = $get_to_date->format('Y-m-d');

        $date1 = new DateTime($from_date);
        $date2 = new DateTime($to_date);
        $interval = $date1->diff($date2);
        $day_count = $interval->format('%a');
      }

        $user_id = $this->user->id;
        $rows['graph'] = $this->events_model->my_promo_graph_model($from_date, $to_date, $user_id);            
        $result = count($rows['graph']);
        $data['data'] = array();
        if($result > 0){

            array_push($data['data'], array('DATE', 'Sales'));
               foreach($rows['graph'] as $row){
                    array_push($data['data'], array($row['date_display'], (int)$row['ticketss_sold_on_date'])); 
               } 

        }
        else{
            $i = 1;
            $day_count = $day_count == 0 ? 1 : $day_count;
            array_push($data['data'], array('DATE', 'Sales'));
            while($i <= $day_count){
                array_push($data['data'], array(date('Y-m-'.$i), 0 ));
                $i++;
            }

        }


       echo json_encode($data);          
  }

,这是我的模特

public function my_promo_graph_model($from_date, $to_date, $user_id){

        $this->db->select('DATE(tickets_sold.date) AS date_display,
                          SUM(tickets_sold.quantity) AS ticketss_sold_on_date,
                          SUM(tickets_sold.quantity*tickets_sold.price) AS money_earned');

        $this->db->join('tickets_sold', 'tickets_sold.event_date_id = my_promos.event_id');
        $this->db->where('my_promos.user_id', $user_id);
        $this->db->where('DATE(tickets_sold.date) >=', $from_date);
        $this->db->where('DATE(tickets_sold.date) <=', $to_date);
        $this->db->group_by('date_display');
        $query = $this->db->get('my_promos');
        return $query->result_array();
    }

1 个答案:

答案 0 :(得分:0)

在查询之前检查PHP中的日期范围,然后要求MySQL按周而不是白天进行分组,如评论中的链接所示。目前你要求:

$this->db->group_by('date_display');

尝试:

$this->db->group_by('YEARWEEK(date_display, 3)');

您想要的week mode可能与此不同。使用YEARWEEK而不仅仅是WEEK意味着您可以安全地进行排序。