Премини към съдържанието
Форумът в приложение

По-лесно сърфиране. Научи повече.

Kaldata.com - Форуми

Приложение на форума на цял екран с push известия, значки и други.

За да инсталирате това приложение на iOS и iPadOS
  1. Докоснете Иконата за споделяне в Safari
  2. Превъртете менюто и докоснете Добавяне към началния екран.
  3. Докоснете Добавяне в горния десен ъгъл.
За да инсталирате това приложение на Android
  1. Докоснете менюто с 3 точки (⋮) в горния десен ъгъл на браузъра.
  2. Докоснете Добавяне към началния екран или Инсталиране на приложение.
  3. Потвърдете, като докоснете Инсталиране.

Добре дошли!

Добре дошли в нашите форуми, пълни с полезна информация. Имате проблем с компютъра или телефона си? Публикувайте нова тема и ще намерите решение на всичките си проблеми. Общувайте свободно и открийте безброй нови приятели.

Моля, регистрирайте се за да публикувате тема и да получите пълен достъп до всички функции.

 

Проблем с извеждане на новини

Featured Replies

Здравейте. Имам база данни с 2 таблици - новини и коментари.
И имам проблем с извеждането на новините. Когато добавя новина тя се показва , показва и броя на коментарите , но когато добавя 2ра новина се показва само 1вата.
Направил съм и странициране и съм задал да се показват по 3 на страница , но се показва само първата. Когато направя да се показва 1 на страница на втората страница се показва втората новина.
Как да оправя този проблем , искам да извежда всички новини. Пробвах с премахването на страницирането , но ефекта е същия показва само една.
 
Тук е кода ми -> https://pastebin.com/JyeM049w

Ако не можеш сам да си напишеш читав код, или плати на програмист или ползвай CMS, избор има WordPress, Joomla, Drupal, теми и плъгини  колкото душа ти иска :)

  • Автор
преди 1 час, Android Test2me написа:

Ако не можеш сам да си напишеш читав код, или плати на програмист или ползвай CMS, избор има WordPress, Joomla, Drupal, теми и плъгини  колкото душа ти иска :)

Напълно излишен и неъместен коментар. Ще е добре да се придържате към темата :)

Свикнал съм framework да върши тази мръсна работа, но мисля, че видях проблема.

while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {  
	$category->id = $row['category_id'];
	$category->readCategoryName();

С "$row = $stmt->fetch(PDO::FETCH_ASSOC)" не се ли взима един ред от базата данни и след това се показва ? Не виждам как продължава loop...

Не трябва ли да е така:

$rows = $stmt->fetchAll();

foreach($rows as $row) {
	$category->id = $row['category_id'];
	$category->readCategoryName();
	...

 

  • Автор
преди 2 часа, Random Person написа:

Свикнал съм framework да върши тази мръсна работа, но мисля, че видях проблема.


while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {  
	$category->id = $row['category_id'];
	$category->readCategoryName();

С "$row = $stmt->fetch(PDO::FETCH_ASSOC)" не се ли взима един ред от базата данни и след това се показва ? Не виждам как продължава loop...

Не трябва ли да е така:


$rows = $stmt->fetchAll();

foreach($rows as $row) {
	$category->id = $row['category_id'];
	$category->readCategoryName();
	...

 

Да , това реши проблема ми. Би ли ми обяснил каква точно е грешката ми ?

преди 50 минути, Румен Радев написа:

Да , това реши проблема ми. Би ли ми обяснил каква точно е грешката ми ?

Kaкто споменах, "$row = $stmt->fetch(PDO::FETCH_ASSOC)" взима само първият ред и не продължава. fetch() връща един ред, а PDO::FETCH_ASSOC настройва PDO резултата да е под формата на associative array. Реално while работи като if според мен.

Ако ще се използва while loop, като гледам документацията има няколко начина да се направи. При PDO::FETCH_ASSOC в while loop не е достатъчно само стойността като условие, както е направено на повечето места, а нещо такова би трябвало да реши проблема:

while (($row = $stmt->fetch(PDO::FETCH_ASSOC)) !== false ) {
...

Също има вариант за извеждане с scrollable cursor на fetch(). Погледни документацията, която реално на части написах по-горе. 

  • Автор
преди 20 часа, Random Person написа:

Kaкто споменах, "$row = $stmt->fetch(PDO::FETCH_ASSOC)" взима само първият ред и не продължава. fetch() връща един ред, а PDO::FETCH_ASSOC настройва PDO резултата да е под формата на associative array. Реално while работи като if според мен.

Ако ще се използва while loop, като гледам документацията има няколко начина да се направи. При PDO::FETCH_ASSOC в while loop не е достатъчно само стойността като условие, както е направено на повечето места, а нещо такова би трябвало да реши проблема:


while (($row = $stmt->fetch(PDO::FETCH_ASSOC)) !== false ) {
...

Също има вариант за извеждане с scrollable cursor на fetch(). Погледни документацията, която реално на части написах по-горе. 

Ясно ,  лагодаря ти :) Ето това е мнение. Много благодаря за отговора.

Архивирана тема

Темата е твърде стара и е архивирана. Не можете да добавяте нови отговори в нея, но винаги можете да публикувате нова тема, в която да продължи дискусията. Регистрирайте се или влезте във вашия профил за да публикувате нова тема.

Разглеждащи това в момента 0

  • Няма регистрирани потребители разглеждащи тази страница.

Дарение

  • Подкрепи съществуването на форума - направи дарение
    25%
    Дарени 252.69 EUR от нужните 1,000.00 EUR

Бюлетин

Получавайте известие, когато има важна промяна или новина свързана с форума.

Профил

Навигация

Търсене

Търсене

Конфигуриране на push известия в браузъра

Chrome (Android)
  1. Докоснете иконата на катинар до адресната лента.
  2. Докоснете Разрешения → Известия.
  3. Променете предпочитанията си.
Chrome (Desktop)
  1. Кликнете върху иконата на катинар в адресната лента.
  2. Изберете Настройки на сайта.
  3. Намерете Известия и коригирайте предпочитанията си.