WebClub - Всероссийский Клуб Веб-разработчиков
WebClub.RU » Советы » Система "Совет дня". Часть 2

Система "Совет дня". Часть 2


Дата публикации: 01-12-2010

NAS, Webscript.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)) {
// код обработки
}

Продумать алгоритм генерации ссылок на предыдущую и следующую страницу предлагаю вам самостоятельно. Если это вызывает большие затруднения, то пишите мне (exper@inbox.ru). В следующем опыте рассмотрим как реализуется часть, которая отвечает за размещение текста совета на чужих страницах.

Домен продается

Популярное

Не так давно в сети появился новый сервис, под названием Dead Man Zero. Этот сервис сделал...
Рынок социальных площадок уже давно стал стабильным. Несмотря на то, что время от времени...
Artisteer 4 – единственный в своем роде продукт, позволяющий автоматизировать работу над созданием...
Апрель 2024 (1)
Октябрь 2018 (14)
Февраль 2017 (3)
Январь 2017 (1)
Август 2016 (1)
Май 2016 (2)

Карта сайта: 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41

Друзья сайта



Случайная цитата

Alan J. Perlis:

"Низкоуровневый язык — это когда требуется внимание к вещам, которые никак не связаны с программами на этом языке."

Опрос

Какой аудио плеер Вы используете?

Winamp
Light Alloy
foobar2000
Apollo
AIMP
1by1
iTunes
jetAudio
Другой...