我在我的代码点火器项目中使用 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 日的任何内容都不会显示。
最好的办法可能是只增加一天,使用更少的时间,而不是查找前一天发生的任何事情。