带有 CodeIgniter 的 JQuery 日期选择器


JQuery Date Picker with CodeIgniter

我在我的代码点火器项目中使用 jQuery 日期选择器

在我看来,我是这样使用它

  <script>
     $(function() {
       $( "#from-datepicker" ).datepicker();
     });
  </script>
  <script>
    $(function() {
      $( "#to-datepicker" ).datepicker();
    });
  </script>
  <div style="float:left; width:330px">
     <input name="from-date" type="text" id="from-datepicker" />
  </div>
  <div style="float:left; width:330px">
     <input name="to-date" type="text" id="to-datepicker" />
  </div>

在我的控制器中,我有

public function titlesDownloads(){
    if($_POST){
        $form = $this->input->post();
        $boxes = $form['boxes'];
        $titles = $form['titles'];
        $from_date = date('Y-m-d',strtotime($form['from-date']));
        $to_date = date('Y-m-d',strtotime($form['to-date']));
        $data['titles_downloads'] = $this->Statistic_model->getTitlesDownloads($boxes, $titles, $ipsegments, $from_date, $to_date);
        $data['from_date'] = $from_date;
        $data['to_date'] = $to_date;
        $this->load->view('statistic/titles-downloads', $data);
    }
}

在我的模型中,我有将下载次数获取为

  public function getTitlesDownloads($boxes, $titles, $from_date, $to_date){
    $query = $this->db->select('mc_boxes_idmc_boxes, mc_boxes.location, idtitle_history, titles.title, COUNT(mc_boxes_has_downloads.idtitle_history) AS Titles_Downloads ')
            ->from('mc_boxes_has_downloads')
            ->join('mc_boxes', 'mc_boxes_has_downloads.mc_boxes_idmc_boxes = mc_boxes.idmc_boxes', 'left')
            ->join('titles', 'mc_boxes_has_downloads.idtitle_history = titles.idtitles', 'left')
            ->where_in('mc_boxes_idmc_boxes', $boxes)
            ->where_in('idtitle_history', $titles)
            ->where('actiontime >=', $from_date)
            ->where('actiontime <=', $to_date)
            ->group_by('mc_boxes_idmc_boxes')
            ->group_by('idtitle_history')
            ->get();
    $data = $query->result_array();
    return $data;
}

现在,对于特定的标题 id=7,6 月份有 4 次下载。 但是当我运行查询时,它返回我三个。跳过 6 月 30 日的最后一次下载。

我认为日期选择器跳过了所选日期的上限和下限。虽然在我的查询中我写了>= 开始日期和>=结束日期。

为什么跳过最后日期?

知道吗?

谢谢

由于您只是传递日期而没有时间,因此可能假设时间是午夜。 因此,不到 6 月 30 日午夜,6 月 30 日的任何内容都不会显示。

最好的办法可能是只增加一天,使用更少的时间,而不是查找前一天发生的任何事情。