我有一个过滤器,它从日期过滤器基础上的数据库中获取数据,该过滤器查找两个日期之间的数据。例如从= 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();
}
答案 0 :(得分:0)
在查询之前检查PHP中的日期范围,然后要求MySQL按周而不是白天进行分组,如评论中的链接所示。目前你要求:
$this->db->group_by('date_display');
尝试:
$this->db->group_by('YEARWEEK(date_display, 3)');
您想要的week mode可能与此不同。使用YEARWEEK而不仅仅是WEEK意味着您可以安全地进行排序。