вывод строк из БД и последующая их выборка по определенным критериям
Все привет, решил обратиться к специалистам, уже несколько дней не могу разобраться, ибо только начал изучать php. Необходимо написать скрипт вывода информации из таблицы 'music'. Имеются поля 'author' - исполнитель, 'title' - название, 'date' - дата, в формате YYYY-MM-DD, 'link'- относительная ссылка на файл в папке на сервере.
Есть такой код, с пагинацией и выводом лишь записей:
/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .php.geshi_code {font-family:monospace;} .php.geshi_code .imp {font-weight: bold; color: red;} .php.geshi_code .kw1 {color: #b1b100;} .php.geshi_code .kw2 {color: #000000; font-weight: bold;} .php.geshi_code .kw3 {color: #990000;} .php.geshi_code .co1 {color: #666666; font-style: italic;} .php.geshi_code .co2 {color: #666666; font-style: italic;} .php.geshi_code .co3 {color: #0000cc; font-style: italic;} .php.geshi_code .co4 {color: #009933; font-style: italic;} .php.geshi_code .coMULTI {color: #666666; font-style: italic;} .php.geshi_code .es0 {color: #000099; font-weight: bold;} .php.geshi_code .es1 {color: #000099; font-weight: bold;} .php.geshi_code .es2 {color: #660099; font-weight: bold;} .php.geshi_code .es3 {color: #660099; font-weight: bold;} .php.geshi_code .es4 {color: #006699; font-weight: bold;} .php.geshi_code .es5 {color: #006699; font-weight: bold; font-style: italic;} .php.geshi_code .es6 {color: #009933; font-weight: bold;} .php.geshi_code .es_h {color: #000099; font-weight: bold;} .php.geshi_code .br0 {color: #009900;} .php.geshi_code .sy0 {color: #339933;} .php.geshi_code .sy1 {color: #000000; font-weight: bold;} .php.geshi_code .st0 {color: #0000ff;} .php.geshi_code .st_h {color: #0000ff;} .php.geshi_code .nu0 {color: #cc66cc;} .php.geshi_code .nu8 {color: #208080;} .php.geshi_code .nu12 {color: #208080;} .php.geshi_code .nu19 {color:#800080;} .php.geshi_code .me1 {color: #004000;} .php.geshi_code .me2 {color: #004000;} .php.geshi_code .re0 {color: #000088;} .php.geshi_code span.xtra { display:block; }
<?php
include('config.php');
$lim = "9"; //лимит записей на страницу
@$page = $_GET['page'];
$res = mysql_query("SELECT COUNT(*) FROM music");
$row = mysql_fetch_array($res);
$posts = $row[0];
$str = ceil($posts/$lim);
if(empty($page) or $page < 0) $page = 1;
if($page > $str) $page = $str;
$start = $page * $lim - $lim;
$result = mysql_query("SELECT * FROM music ORDER BY date DESC LIMIT $start, $lim");
while ($myrow = mysql_fetch_array ($result))
{
printf ("
<div id='mp3'>
<h5 style='margin: 20px;'>".$myrow['artist']." - ".$myrow['title']."<a href='".$myrow['link']."'>Скачать</a></h5>
</div>
");}
while ($myrow = mysql_fetch_array ($result));
echo '<div id="navi_n"><a href=?page='. ($page - 1) .'>Назад</a> ';
$i=1;
while ($i <= $str)
{
if ($i==$page)
{echo '<strong><a href=?page='.$i.'>'.$i.'</a></strong> ';}
else
{echo '<a href=?page='.$i.'>'.$i.'</a> ';}
$i = $i+1;
}
echo ' <a href=?page='. ($page + 1) .'>Вперед</a></div>';
?>
Вопрос 1: Как мне составить запросы так, что-бы пользователь при нажатии на имя автора получил все треки только этого автора?
Вопрос 2: Необходимо сделать выборку по месяцу, т.е. пользователь нажимает на "Январь", и пользователю отображаются все треки за Январь?
Вопрос 3: Из текущего кода реально как-нибудь сделать пагинатор на jquery без перезагрузки страницы?
Заранее благодарю.
Есть такой код, с пагинацией и выводом лишь записей:
/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .php.geshi_code {font-family:monospace;} .php.geshi_code .imp {font-weight: bold; color: red;} .php.geshi_code .kw1 {color: #b1b100;} .php.geshi_code .kw2 {color: #000000; font-weight: bold;} .php.geshi_code .kw3 {color: #990000;} .php.geshi_code .co1 {color: #666666; font-style: italic;} .php.geshi_code .co2 {color: #666666; font-style: italic;} .php.geshi_code .co3 {color: #0000cc; font-style: italic;} .php.geshi_code .co4 {color: #009933; font-style: italic;} .php.geshi_code .coMULTI {color: #666666; font-style: italic;} .php.geshi_code .es0 {color: #000099; font-weight: bold;} .php.geshi_code .es1 {color: #000099; font-weight: bold;} .php.geshi_code .es2 {color: #660099; font-weight: bold;} .php.geshi_code .es3 {color: #660099; font-weight: bold;} .php.geshi_code .es4 {color: #006699; font-weight: bold;} .php.geshi_code .es5 {color: #006699; font-weight: bold; font-style: italic;} .php.geshi_code .es6 {color: #009933; font-weight: bold;} .php.geshi_code .es_h {color: #000099; font-weight: bold;} .php.geshi_code .br0 {color: #009900;} .php.geshi_code .sy0 {color: #339933;} .php.geshi_code .sy1 {color: #000000; font-weight: bold;} .php.geshi_code .st0 {color: #0000ff;} .php.geshi_code .st_h {color: #0000ff;} .php.geshi_code .nu0 {color: #cc66cc;} .php.geshi_code .nu8 {color: #208080;} .php.geshi_code .nu12 {color: #208080;} .php.geshi_code .nu19 {color:#800080;} .php.geshi_code .me1 {color: #004000;} .php.geshi_code .me2 {color: #004000;} .php.geshi_code .re0 {color: #000088;} .php.geshi_code span.xtra { display:block; }
<?php
include('config.php');
$lim = "9"; //лимит записей на страницу
@$page = $_GET['page'];
$res = mysql_query("SELECT COUNT(*) FROM music");
$row = mysql_fetch_array($res);
$posts = $row[0];
$str = ceil($posts/$lim);
if(empty($page) or $page < 0) $page = 1;
if($page > $str) $page = $str;
$start = $page * $lim - $lim;
$result = mysql_query("SELECT * FROM music ORDER BY date DESC LIMIT $start, $lim");
while ($myrow = mysql_fetch_array ($result))
{
printf ("
<div id='mp3'>
<h5 style='margin: 20px;'>".$myrow['artist']." - ".$myrow['title']."<a href='".$myrow['link']."'>Скачать</a></h5>
</div>
");}
while ($myrow = mysql_fetch_array ($result));
echo '<div id="navi_n"><a href=?page='. ($page - 1) .'>Назад</a> ';
$i=1;
while ($i <= $str)
{
if ($i==$page)
{echo '<strong><a href=?page='.$i.'>'.$i.'</a></strong> ';}
else
{echo '<a href=?page='.$i.'>'.$i.'</a> ';}
$i = $i+1;
}
echo ' <a href=?page='. ($page + 1) .'>Вперед</a></div>';
?>
Вопрос 1: Как мне составить запросы так, что-бы пользователь при нажатии на имя автора получил все треки только этого автора?
Вопрос 2: Необходимо сделать выборку по месяцу, т.е. пользователь нажимает на "Январь", и пользователю отображаются все треки за Январь?
Вопрос 3: Из текущего кода реально как-нибудь сделать пагинатор на jquery без перезагрузки страницы?
Заранее благодарю.
1 ответов
Вопрос 1: Как мне составить запросы так, что-бы пользователь при нажатии на имя автора получил все треки только этого автора?
Ответ:
if (isset($_GET["author"])) {
$query = "\n SELECT * FROM `music` WHERE `author` = '".$_GET["author"]."' LIMIT $start, $lim";
$result = mysql_query($query);
if ($result && @intval($result) != -1) {
// выводим результат
}
}
Или если используется поиск по имени автору. Найти авторов по шаблону
if (isset($_GET["author"])) {
$query = "\n SELECT * FROM `music` WHERE `author` = LIKE('%".$_GET["author"]."%') LIMIT $start, $lim";
$result = mysql_query($query);
if ($result && @intval($result) != -1) {
// выводим результат
}
}
Вопрос 2: Необходимо сделать выборку по месяцу, т.е. пользователь нажимает на "Январь", и пользователю отображаются все треки за Январь?
Ответ:
if (isset($_GET["month"])) {
// MONTH это функция SQL. Соответственно $month должно быть 1 до 12
$query = "\n SELECT * FROM `music` WHERE MONTH(`date`) = '".$_GET["month"]."' LIMIT $start, $lim";
$result = mysql_query($query);
if ($result && @intval($result) != -1) {
// выводим результат
}
}
Вопрос 3: Из текущего кода реально как-нибудь сделать пагинатор на jquery без перезагрузки страницы?
Ответ: Конечно реально. Но, это далеко не лучший вариант архитектурного решения. Вы не сможете передать по ссылке страницу, так как адреса не будет существовать, а также, ваш контент, не будет индексировать поисковики. В добавок отлаживать такое будет в разы сложней. Вы уверены что вам действительно такое нужно?
Я дам скорее совет, чем ответ. @volovikov вам все расписал.
Конечно, все мы проходили через такой говнокод, но пора взяться за ум и начинать писать грамотный код, иначе php так и будут считать говноязыком для говнокодеров (я люблю php и никого не хочу оскорбить).
Поэтому, дам вам список материалов, для расширения кругозора и становления на путь нормального программера-профи:
- Как избежать SQL инъекций
- Проникнитесь написанием объектно-ориентированного кода на php и вообще в целом
- Проникнитесь идеей разделения кода (php) от данных (html). То бишь MVC, например
- Шикарный материал про паттерны в программировании, как раз для начинающих
- Попробуйте освоить не очень сложный php-фреймворк, от себя рекомендую Kohana Framework, для начала подойдут видео-уроки, потом уже перейдете на документацию
Если возникнут какие-то вопросы по поводу объектно-ориентированного подхода и MVC, можете писать мне в личку, что знаю - расскажу :)