簡體   English   中英

為什么SQL SELECT語句不檢索PHP日歷的相關日期?

[英]Why is SQL SELECT statement not retrieving relevant dates for PHP calendar?

我正在嘗試根據David Walsh的示例在PHP和SQL中構建事件日歷。 他的示例相當古老,並使用了不推薦使用的函數,例如mysql_query,因此我嘗試使用PDO進行現代化。 到目前為止,我已經設法打印出日歷,並且能夠選擇不同的月份和年份。 我還成功創建了數據庫連接。 該表由一個ID(自動遞增),標題(varchar)和event_date(日期)組成。 我在表中填充了一些事件,但似乎無法成功檢索它們。 我在頂部包含了代碼中最相關的部分,但是我將整個代碼復制到上下文中。

我對數據庫的查詢

$events = array();
try {   $results = $db->query("SELECT title, DATE_FORMAT(event_date,'%Y-%m-%d') AS event_date FROM events WHERE event_date LIKE '$year-$month'");
        echo "<pre>";
        var_dump($results);
} catch (Exception $e) {
    echo "cannot get results!";
    exit;
}

$bookings = $results->fetchAll(PDO::FETCH_ASSOC);

while($row = $bookings) {
    $events[$row['event_date']][] = $row;
}

echo '<pre>';
var_dump($bookings);

我的var_dump對$ results的結果

object(PDOStatement)#2 (1) {
  ["queryString"]=>
  string(105) "SELECT title, DATE_FORMAT(event_date,'%Y-%m-%d') AS event_date FROM events WHERE event_date LIKE '2014-1'"
}

$ bookings上的var_dump說我的數組為空

 array(0) {
    }

上下文的完整代碼

<?php 

require('database.php');

/* draws a calendar */
function draw_calendar($month,$year,$events = array()){

    /* draw table */
    $calendar = '<table cellpadding="0" cellspacing="0" class="calendar">';

    /* table headings */
    $headings = array('Sontag','Montag','Dienstag','Mittwoch','Donnerstag','Freitag','Samstag');
    $calendar.= '<tr class="calendar-row"><td class="calendar-day-head">'.implode('</td><td class="calendar-day-head">',$headings).'</td></tr>';

    /* days and weeks vars now ... */
    $running_day = date('w',mktime(0,0,0,$month,1,$year));
    $days_in_month = date('t',mktime(0,0,0,$month,1,$year));
    $days_in_this_week = 1;
    $day_counter = 0;
    $dates_array = array();

    /* row for week one */
    $calendar.= '<tr class="calendar-row">';

    /* print "blank" days until the first of the current week */
    for($x = 0; $x < $running_day; $x++):
        $calendar.= '<td class="calendar-day-np">&nbsp;</td>';
        $days_in_this_week++;
    endfor;

    /* keep going with days.... */
    for($list_day = 1; $list_day <= $days_in_month; $list_day++):
        $calendar.= '<td class="calendar-day"><div style="position:relative;height:100px;">';
            /* add in the day number */
            $calendar.= '<div class="day-number">'.$list_day.'</div>';

            $event_day = $year.'-'.$month.'-'.$list_day;
            if(isset($events[$event_day])) {
                foreach($events[$event_day] as $event) {
                    $calendar.= '<div class="event">'.$event['title'].'</div>';
                }
            }
            else {
                $calendar.= str_repeat('<p>&nbsp;</p>',2);
            }
        $calendar.= '</div></td>';
        if($running_day == 6):
            $calendar.= '</tr>';
            if(($day_counter+1) != $days_in_month):
                $calendar.= '<tr class="calendar-row">';
            endif;
            $running_day = -1;
            $days_in_this_week = 0;
        endif;
        $days_in_this_week++; $running_day++; $day_counter++;
    endfor;

    /* finish the rest of the days in the week */
    if($days_in_this_week < 8):
        for($x = 1; $x <= (8 - $days_in_this_week); $x++):
            $calendar.= '<td class="calendar-day-np">&nbsp;</td>';
        endfor;
    endif;

    /* final row */
    $calendar.= '</tr>';


    /* end the table */
    $calendar.= '</table>';

    /** DEBUG **/
    $calendar = str_replace('</td>','</td>'."\n",$calendar);
    $calendar = str_replace('</tr>','</tr>'."\n",$calendar);

    /* all done, return result */
    return $calendar;
}

function random_number() {
    srand(time());
    return (rand() % 7);
}

/* date settings */
$month = (int) ($_GET['month'] ? $_GET['month'] : date('m'));
$year = (int)  ($_GET['year'] ? $_GET['year'] : date('Y'));

/* select month control */
$select_month_control = '<select name="month" id="month">';
for($x = 1; $x <= 12; $x++) {
    $select_month_control.= '<option value="'.$x.'"'.($x != $month ? '' : ' selected="selected"').'>'.date('F',mktime(0,0,0,$x,1,$year)).'</option>';
}
$select_month_control.= '</select>';

/* select year control */
$year_range = 7;
$select_year_control = '<select name="year" id="year">';
for($x = ($year-floor($year_range/2)); $x <= ($year+floor($year_range/2)); $x++) {
    $select_year_control.= '<option value="'.$x.'"'.($x != $year ? '' : ' selected="selected"').'>'.$x.'</option>';
}
$select_year_control.= '</select>';

/* "next month" control */
$next_month_link = '<a href="?month='.($month != 12 ? $month + 1 : 1).'&year='.($month != 12 ? $year : $year + 1).'" class="control">Next Month &gt;&gt;</a>';

/* "previous month" control */
$previous_month_link = '<a href="?month='.($month != 1 ? $month - 1 : 12).'&year='.($month != 1 ? $year : $year - 1).'" class="control">&lt;&lt;    Previous Month</a>';


/* bringing the controls together */
$controls = '<form method="get">'.$select_month_control.$select_year_control.'&nbsp;<input type="submit" name="submit" class="btn btn-default" value="Go" />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;'.$previous_month_link.'&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;'.$next_month_link.' </form>';

/* get all events for the given month */
$events = array();
try {   $results = $db->query("SELECT title, DATE_FORMAT(event_date,'%Y-%m-%d') AS event_date FROM events WHERE event_date LIKE '$year-$month'");
        echo "<pre>";
        var_dump($results);
} catch (Exception $e) {
    echo "cannot get results!";
    exit;
}

$bookings = $results->fetchAll(PDO::FETCH_ASSOC);

while($row = $bookings) {
    $events[$row['event_date']][] = $row;
}

echo '<pre>';
var_dump($bookings);

echo '<h2 style="float:left; padding-right:30px;">'.date('F',mktime(0,0,0,$month,1,$year)).' '.$year.'</h2>';
echo '<div style="float:left;">'.$controls.'</div>';
echo '<div style="clear:both;"></div>';
echo draw_calendar($month,$year,$events);
echo '<br /><br />';

除了喜歡的問題

FetchAll獲取整個集合,因此雖然無法正常工作。請使用foreach

foreach ($bookings as $row) {
    $events[$row['event_date']][] = $row;
}

同樣在您使用賦值運算符而不是比較==

我認為您在sql查詢字符串中忘記了通配符。

您可以嘗試以下方法:

WHERE event_date LIKE '$year-$month%'"

如果將event_date列作為日期而不是文本字段來處理,則效果會更好。

試試這個查詢:

SELECT title, 
       DATE_FORMAT(event_date,'%Y-%m-%d') AS event_date 
  FROM events
 WHERE event_date >= DATE(DATE_FORMAT(NOW(),'%Y-%m-01'))
   AND event_date <  DATE(DATE_FORMAT(NOW(),'%Y-%m-01')) + INTERVAL 1 MONTH

這將找到event_date所有event_date值,同時將使用event_date上的MySQL索引進行搜索(如果有的話)。

如果您想要上個月的活動,則可以這樣做。

 WHERE event_date >= DATE(DATE_FORMAT(NOW(),'%Y-%m-01')) - INTERVAL 1 MONTH
   AND event_date <  DATE(DATE_FORMAT(NOW(),'%Y-%m-01'))

這是對該主題的介紹。 http://www.plumislandmedia.net/mysql/sql-reporting-time-intervals/

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM