Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Выборка из многомерного массива с условиями

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
robbin
Отправлено: 16 Февраля, 2014 - 14:11:27
Post Id


Новичок


Покинул форум
Сообщений всего: 2
Дата рег-ции: Февр. 2014  


Помог: 0 раз(а)




Доброго времени суток. Сразу прошу прощения если этот вопрос уже раскрыт, но пользуясь поиском я его не нашел.
Собственно вопрос в следующем. Имеется многомерный массив с полями number, brand, article, price, weight, qty, sklad, term. Массив этот отсортирован по term и price. Записей с одинаковым term может быть несколько. задача состоит в том, чтобы выбрать из массива по 1 записи с каждым из term и минимальным price.
Уж очень кажется мне неправильным перебирать все записи массива и сравнивать между собой. Надеюсь что есть более логичное и грамотное решение.
Надеюсь описал доступно.

(Отредактировано автором: 16 Февраля, 2014 - 14:12:31)

 
 Top
Мелкий Супермодератор
Отправлено: 16 Февраля, 2014 - 14:41:18
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




На уровне базовой логики всё равно будет перебор всего, что есть. Вопрос в объёме кода. (и сколько раз проходить массив)
Поскольку массив отсортирован уже и по нужным полям, то это упрощает дело. price в какую сторону отсортирован?
0) если первым - минимальное значение, то делаете:
PHP:
скопировать код в буфер обмена
  1. $sLastTerm = null;
  2. $rgOutput = array();
  3. foreach ($rgInput as $item) {
  4. if ($item['term'] != $sLastTerm) { // если term изменился, значит у текущего элемента минимальный price
  5. $rgOutput[] = $item;
  6. $sLastTerm = $item['term'];
  7. }
  8. }

1) если первым - максимальное значение - то можно сделать array_reverse и получим пункт 0 или изменить логику обхода. Например, сэкономим в объёме кода, и воспользуемся уникальностью ключа:
PHP:
скопировать код в буфер обмена
  1. $rgOutput = array();
  2. foreach ($rgInput as $item) {
  3. $rgOutput[ $item['term'] ] = $item; // на каждой итерации элемент будет перезаписан, и, в итоге, будет содержать последний элемент массива для каждого term
  4. // ремарка по сомнениям в производительности - PHP5 значения копирует по ссылке, поэтому очевидное решение не является худшим
  5. }


-----
PostgreSQL DBA
 
 Top
robbin
Отправлено: 16 Февраля, 2014 - 14:51:09
Post Id


Новичок


Покинул форум
Сообщений всего: 2
Дата рег-ции: Февр. 2014  


Помог: 0 раз(а)




Мелкий пишет:
На уровне базовой логики всё равно будет перебор всего


Спасибо большое, помогло.
(Добавление)
Еще маленькое уточнение, а как тут можно отследить уникальность number и brand? Если необходимо, чтобы в рамках одного term бы ли представлены все имеющиеся number и brand. Уникальность должна быть именно по паре number-brand.
(Добавление)
Может через временный массив который и будет содержать эти ключи а потом по окончанию перебора его убивать?

(Отредактировано автором: 16 Февраля, 2014 - 15:14:56)

 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Хранение данных, их вывод и обработка »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB