Правила     Закладки     Карма    Календарь    Журналы    Помощь    Поиск    PDA    Чат   
        СМС-ки
   
Пейджер выключен!
 
Фильтр авторов:    показать 
  скрыть
  Ответ в темуСоздание новой темыСоздание опроса

> Вывод 2 последних статей через foreach
alekseykk  
 ۩  Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Новичок
*

Профиль
Группа: Пользователь
Сообщений: 20
Пользователь №: 40999
На форуме: 10 лет, 2 месяца, 12 дней
Карма:




Всем привет! потихоньку изучаю php, сейчас особенно каша после Попова...так вот...

Цель - вывести все категории из базы, а под каждой из этих категорий должен быть вывод новостей, относящихся к этим категориям.

$resultat = mysqli_query($link, "SELECT `id`,`cat`,`title` FROM `categories`");
$categories = mysqli_fetch_all($resultat, MYSQLI_ASSOC);

$result = mysqli_query($link, "SELECT `id`,`cat`,`title` FROM `data`");
$data = mysqli_fetch_all($result, MYSQLI_ASSOC);

foreach($categories as $ca) {
echo '<a href=#">'.$ca['title'].'</a><br>';

foreach ($data as $single){
if ($single['cat'] == $ca['cat']){
echo '<a href=#">'.$single['title'].'</a><br>';
}
}
echo '</div>';
}


НО как сделать, чтобы под каждой категорией выводились последние две новости? а не все как сейчас...пробовал вот так -

$result = mysqli_query($link, "SELECT `id``,`cat`,`title` FROM `data` ORDER BY `id`DESC LIMIT 2");


но ничего не вышло( как можно реализовать?
PM
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
Hello  
Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Здесь живет
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 837
Пользователь №: 32378
На форуме: 13 лет, 5 дней
Карма: 50




$result = mysqli_query($link, "SELECT `id`,`cat`,`title` FROM `data` ORDER BY `id` DESC"); 
$data = mysqli_fetch_all($result, MYSQLI_ASSOC);

foreach($categories as $ca) {
echo '<a href=#">'.$ca['title'].'</a><br>';

$limit = 2;
foreach ($data as $single){
if ($single['cat'] == $ca['cat'] && $limit-- > 0){
echo '<a href=#">'.$single['title'].'</a><br>';
}
}
echo '</div>';
}


--------------------
VPS от 5$, первые 2 месяца - бесплатно.
PM
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
alekseykk  
 ۩  Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Новичок
*

Профиль
Группа: Пользователь
Сообщений: 20
Пользователь №: 40999
На форуме: 10 лет, 2 месяца, 12 дней
Карма:




Hello

Большое спасибо! то есть через $limit = 2; задали лимит на вывод двух новостей?, а здесь к проверке добавили $limit-- > 0, не особо понял значение, что он делает? черт не могу вспомнить про стрелочки laugh.gif
PM
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
Winston  
Дата
Цитировать сообщение

Пользователя сейчас нет на форуме




******

Профиль
Группа: Эксперт
Группа переписки
Сообщений: 9509
Пользователь №: 18161
На форуме: 15 лет, 10 месяцев, 21 день
Карма: 552




Декремент.
На каждой итерации $limit будет уменьшаться на 1, и проверка, что если $limit после декремента все еще больше нуля, то выводим название.
PMСайт пользователя
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
alekseykk  
 ۩  Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Новичок
*

Профиль
Группа: Пользователь
Сообщений: 20
Пользователь №: 40999
На форуме: 10 лет, 2 месяца, 12 дней
Карма:




Winston

Понял, спасибо!)
PM
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
  Быстрый ответ
Информация о Госте
Введите Ваше имя
Кнопки кодов
Для вставки цитаты, выделите нужный текст и
НАЖМИТЕ СЮДА
Введите сообщение
Смайлики
:huh:  :o  ;) 
:P  :D  :lol: 
B)  :rolleyes:  <_< 
:)  :angry:  :( 
:unsure:  :blink:  :ph34r: 
     
Показать всё

Опции сообщения  Включить смайлики?
 Включить подпись?
 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:

Опции темы Ответ в темуСоздание новой темыСоздание опроса