0 Пользователей и 1 Гость просматривают эту тему.
  • 7 Ответов
  • 5991 Просмотров
*

dmonco

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
  • http://dmitryboruk.com
Модифицировал VirtueMart, добавил дополнительные страницы.
Так вот на одной из них у меня загвоздка.

Как правильно сделать вложенный цикл и вывести данные?

То есть, на странице должна быть такая таблица:

Заказ    Дата                         Сумма             Скидка    Доставка    Сумма к оплате       Статус
№17      12 января 2009 года      18 711 руб.    15%          300 руб.   20 011 руб.                В обработке

А под ней подробные данные о заказе:

фото 1, характеристика товара 1, цена 1
фото 2, характеристика товара 2, цена 2

Если таких заказов два и больше, соответственно под этой таблицей должна появиться ещё одна такая же таблица для второго заказа.

Предполагаю, что здесь нужен вложенный цикл.
for {

     for{

         }
    }

Пытался сделать что-то в этом роде.


       $user =& JFactory::getUser();
       $db =& JFactory::getDBO();
       $query = 'SELECT order_id AS oid, cdate AS cd, order_subtotal AS ost, order_discount AS od, order_shipping AS osh, order_total AS ot, SUM( order_subtotal ) AS sum_ost, SUM( order_discount ) AS sum_od, SUM( order_shipping ) AS sum_osh, SUM( order_total ) AS sum_ot FROM `jos_vm_orders` WHERE `user_id` = "131" AND `order_status` =  "ЗО" OR  `order_status` =  "ОД" group by cdate';
       $db->setQuery($query);
       $rows = $db->loadObjectList();
 
       foreach ( $rows as $row )



Помогите реализовать данный цикл на php. Своими силами и знаниями не получается.
Заранее спасибо!
*

beliyadm

  • Легенда
  • 9758
  • 1664 / 66
  • Севастополь, Россия
на выходе получается массив из строк, где повторяются данные номер заказа, дата, сумма и характеристики. При этом если в заказе два товара - строк 2, если три - 3 и так далее?
Если да, то я бы делал элементарно (недавно так в одном модуле прекрасно заработало)
делаем счетчиком
Код: php
$i = '0';
foreach ( $rows as $row ) {
 if ($i == '0') {
 echo 'Поля из запроса, которые отвечают за основную информацию о заказе';
 } else {
 echo 'фото 1, характеристика товара 1, цена 1';
 }
$I++;
}
То есть первой строкой мы показываем только основные информации и эта строка у нас будет на выходе одна, остальными выводим столько строк сколько и подробных данных
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

dmonco

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
  • http://dmitryboruk.com
Спасибо! Всё работает.  :D :D :D
*

dmonco

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
  • http://dmitryboruk.com
Поспешил я сказать, что всё работает.
Первое echo выводится как положено, а echo в else не выводится.
Здесь получается, если i будет не равно 0, только тогда срабатывает else.

Может что-то в этом роде сделать?
Код
<?php
$i = '0';
$k = '0';
foreach ( $rows as $row ) {
if ($i == '0') {
 echo $row->значения. 'Поля из запроса, которые отвечают за основную информацию о заказе';
    }
$I++;
elseif ($k == '0') {
 echo '$row->фото 1, характеристика товара 1, цена 1';
        break;
    }
}
endforeach;
?>

То есть два цикла получается.
1 выводит Поля из запроса, которые отвечают за основную информацию о заказе
2 фото 1, характеристика товара 1, цена 1
      фото 2, характеристика товара 2, цена 2

1 выводит Поля из запроса, которые отвечают за основную информацию о заказе2
2-й фото 1, характеристика товара 1, цена 1
      фото 2, характеристика товара 2, цена 2
« Последнее редактирование: 31.12.2009, 04:40:47 от dmonco »
*

beliyadm

  • Легенда
  • 9758
  • 1664 / 66
  • Севастополь, Россия
Прошу прощения, оказывается соврал, в своем модуле делал немного по другому
Код: php
$i = 0;
foreach ( $rows as $row )
{
if ($i == '0') {
    echo 'Первая строка';
} else {}
$i++;
}
$ii = 0;
foreach ( $rows as $row2 )
{
if ($ii != '0') {
    echo 'прочие строки';
} else {}
$ii++;
}
Сейчас смотрю с ужасом и не понимаю зачем я так делал, но то что работало - помню точно. Суть аналогична, пример на сайте в модуле новостей, первый материал выводится полностью с картинкой и текстом, остальные 3-5 только заголовками, все это дело получается из одного запроса
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

dmonco

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
  • http://dmitryboruk.com
Я уже так пробовал. Не вышло.  >:(

Структура страницы такая:

Таблица 1 (которая не повторяется, а выводится один раз)

Таблица 2 //здесь общая информация заказа
(начало)

  Таблица 3 //подробные данные заказа

Таблица 2 //здесь продолжение общей информации о заказе
(конец)

..вроде должно было работать  :'(
*

dmonco

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
  • http://dmitryboruk.com
Может дело в запросе в базу?

У меня на каждый foreach свой запрос:
1       
 
Код
$user =& JFactory::getUser();
$db =& JFactory::getDBO();
$query = 'SELECT order_id AS oid, cdate AS cd, order_subtotal AS ost, order_discount AS od, order_shipping AS osh, order_total AS ot, order_status AS ostat, SUM( order_subtotal ) AS sum_ost, SUM( order_discount ) AS sum_od, SUM( order_shipping ) AS sum_osh, SUM( order_total ) AS sum_ot FROM `jos_vm_orders` WHERE `user_id` = '.$auth['user_id'].' AND `order_status` =  "ЗО" OR  `order_status` =  "ОД" group by cdate';
$db->setQuery($query);
$rows = $db->loadObjectList();
     

2
Код
$user =& JFactory::getUser();
$db2 =& JFactory::getDBO();
$query2 = 'SELECT i.order_id, i.order_item_name AS item, o.order_id, o.user_id FROM jos_vm_order_item AS i INNER JOIN jos_vm_orders AS o ON i.order_id = o.order_id WHERE o.user_id = '.$auth['user_id'].' group by i.order_item_name';
$db2->setQuery($query2);
$rows2 = $db2->loadObjectList()
*

beliyadm

  • Легенда
  • 9758
  • 1664 / 66
  • Севастополь, Россия
мне трудно дать внятное решение не зная какие именно данные находятся в таблицах и выбираются запросами
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Как заставить Joomla 1.5 работать на сервере с MySQL версии 5.7 и выше?

Автор Palomnik

Ответов: 13
Просмотров: 6621
Последний ответ 17.05.2022, 09:07:32
от altvvc
перенесенная Joomla не видит MySQL - в логах MySQL старт нормальный

Автор ommy

Ответов: 23
Просмотров: 5230
Последний ответ 23.01.2018, 11:20:48
от altvvc
MAMP и MySQL

Автор boq

Ответов: 7
Просмотров: 5659
Последний ответ 08.01.2017, 02:25:47
от SeBun
The MySQL adapter "mysqli" is not available

Автор inko_gnito

Ответов: 13
Просмотров: 30471
Последний ответ 27.09.2016, 20:58:27
от lukinalek
[Решено] Unable to connect to the database:Could not connect to MySQL

Автор dircell

Ответов: 82
Просмотров: 164470
Последний ответ 22.01.2016, 19:22:10
от Template_user