Home
Главная
Forums
Форум
Your Account
Ваш аккаунт
Web-технологии
HTML, XML, DHTML
JavaScript
SQL
PHP
Perl
SSI
ASP
CSS

Графика
Adobe PhotoShop
Adobe PhotoShop - 2
Macromedia Flash

Компьютеры
Hardware
Мобильные технологии
КПК и ноутбуки

Операционные системы
Unix/Linux
Windows 9x
Windows XP

Стоит посмотреть
  • Мы предлагаем бюджетные туры в Испанию в недорогие трехзвездочные отели.


  • Отдых в коттеджах в Гелиопарке Эммаус - подробности на портале Best-Pansionat.ru.






  • Система

    В прошлый раз я остановился на ситуации, когда в базе отсутствует совет дня, соответствующий текущей дате. В этом случае нужно выбрать самый поздний совет. Для этого используем следующий SQL-запрос:

    SELECT * FROM tipoad WHERE startdate < NOW() ORDER BY startdate DESC
    

    В переводе на русский это выглядит так: Выбрать все поля из таблицы tipoad, дата выхода которых меньше, чем текущая, отсортировав их в порядке убывания даты. Таким образом в первой строке результата у нас будет находиться информация об искомом совете. На php записываем это так.

    $sql = "SELECT * FROM tipoad WHERE startdate = NOW()";
    $res = mysql_query($sql);
    if (!(mysql_num_rows($res)>0)) {
    $sql = "SELECT * FROM tipoad WHERE startdate < NOW() ORDER BY startdate DESC";
    $res = mysql_query($sql);
    }
    $curTip = mysql_fetch_array($res);
    

    В принципе, этот код избыточен. SQL-запрос можно заменить таким:

    SELECT * FROM tipoad WHERE startdate <= NOW() ORDER BY startdate DESC
    

    Таким образом в первой строке результата мы получим или совет на текущий день или самый поздний из доступных. Следовательно оптимизированный код будет выглядеть так:

    $sql = "SELECT * FROM tipoad WHERE startdate <= NOW() ORDER BY startdate DESC";
    $res = mysql_query($sql);
    $curTip = mysql_fetch_array($res);
    

    Хорошим тоном в программировании считается проверка на правильность выполнения команд. Иначе, в случае ошибки, мы будем получать малоинформативные сообщения. Проверка осуществляется так:

    $res = mysql_query($sql) or die(mysql_error());
    

    При использовании данной конструкции, в случае ошибки, буде остановлено выполнение скрипта и выдано сообщение о причине ошибки.

    Теперь необходимо разработать код для выдачи всех опубликованных на сегодняшний день советов. Для того, чтобы можно было просмотреть пропущенные или вернуться к уже просмотренным ранее.

    Для этого можно использовать тот же SQL-запрос:

    SELECT * FROM tipoad WHERE startdate <= NOW() ORDER BY startdate DESC
    

    Тут есть одна трудность. Если вы, усердно работая над базой советов, продержались (в отличие от меня) год, то такой запрос, во-первых, будет излишне нагружать mySQL, во-вторых, результат будет очень долго перекачиваться клиенту и, в-третьих, займет слишком много места в окне браузера. Для того, чтобы преодолеть эту трудность можно использовать запрос выборки заданного диапазона рядов. Для этого используется выражение LIMIT first,number, где first - номер первого ряда, number - количество выбираемых рядов. Необходимо заметить, что выборка и сортировка (WHERE... и ORDER BY... ) будет производиться до того, как будет наложено ограничение на выбираемый диапазон рядов. Кроме того, если количество выбираемых рядов будет превышать количество рядов в таблице, то операция закончится без ошибки, но в результат попадет только фактическое количество рядов.

    Таким образом, мы имеем инструмент для организации постраничного вывода. Ограничимся семью советами на страницу. Для большей наглядности кода разработаем функцию, которой будем передавать номер необходимой страницы. Номер первой строки будем вычислять путем умножения номера страницы на количество советов на странице. Код выбора советов для текущей страницы будет выглядеть следующим образом.

    function getAllTips($page) {
    $tpp = 7;
    $frst = $page*$tpp;
    $sql = "SELECT * FROM tipoad WHERE startdate <= NOW()
    ORDER BY startdate ASC LIMIT $frst,$tpp";
    $res = mysql_query($sql);
    while ($tip = mysql_fetch_array($res)) {
    // код обработки
    }
    

    Продумать алгоритм генерации ссылок на предыдущую и следующую страницу предлагаю вам самостоятельно. В следующем опыте рассмотрим как реализуется часть, которая отвечает за размещение текста совета на чужих страницах.



    Дополнительно на данную тему:

    Работа с Cookies на PHP
    PHP и Web. Кэширование
    PHP и всё такое....html
    Построение дерева иерархии с помощью PHP / MySQL
    Система 'Совет дня'. Часть 1
    Система Совет дня. (Часть 3)
    Создание системы учета посещений
    Как выучить PHP
    Способы защиты сайта от скачивания
    Модульное программирование на PHP или как написать маленький портал

    Назад | Начало | Наверх
    Rambler's Top100