Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/4: Рейтинг темы: голосов - 4, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 03.05.2019
Сообщений: 7

Как перекрестить между собой значения массива

03.05.2019, 10:13. Показов 847. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте! Есть интернет-магазин, где есть форма с фильтрами каталога. Есть строка в url, например, http://magazin/smartfony?color... ory=128,64

В итоге на сервере обрабатываем ссылку и получаем массив:

PHP
1
2
3
4
5
6
Array(  
[color] => Array ( [0] => gold [1] => black [2] => white )  
[screen_size] => Array ( [0] => 6.5 [1] => 5.8 [2] => 6.1 )  
[brand] => Array ( [0] => apple [1] => samsung )  
[internal_memory] => Array ( [0] => 128 [1] => 64 ) 
)

Не могу понять, как можно перекрестить значения в массиве, чтобы сформировать запрос для mysql. На выходе должно получиться:

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
color='gold' AND screen_size='6.5' AND brand='apple' AND internal_memory='128' 
OR 
color='black' AND screen_size='6.5' AND brand='apple' AND internal_memory='128' 
OR 
color='white' AND screen_size='6.5' AND brand='apple' AND internal_memory='128' 
OR 
color='gold' AND screen_size='5.8' AND brand='apple' AND internal_memory='128' 
OR 
color='black' AND screen_size='5.8' AND brand='apple' AND internal_memory='128' 
OR 
color='white' AND screen_size='5.8' AND brand='apple' AND internal_memory='128' 
OR 
color='gold' AND screen_size='6.1' AND brand='apple' AND internal_memory='128' 
OR 
color='black' AND screen_size='6.1' AND brand='apple' AND internal_memory='128' 
OR 
color='white' AND screen_size='6.1' AND brand='apple' AND internal_memory='128' 
 
и так далее (еще не учли brand (samsung) и internal_memory). Получится еще столько же вариантов.

Параметров может быть как больше, так и меньше

вариантов должно получиться очень очень много, что думаю без рекурсии тут не обойтись, не могу логику понять, как сделать

Добавлено через 43 минуты
Помогите пожалуйста, могу скинуть денег на карту
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
03.05.2019, 10:13
Ответы с готовыми решениями:

Сравнить элементы ассоциативного массива между собой
Приветствую! Есть массив следующего вида: $response = array( "A1F1" => '2', "A1F2" => '3', ...

Как подсчитать количество, используя между собой массивы?
Привет всем. У меня есть два массива один вот такого вида $id_cat_1= array(1 =>15,16,17); в нем хранятся id категорий и еще один ...

Php, соединение элементов шаблона сайта между собой. как правильно?
Сейчас приведу пример конструкции сайта. Имеем, допустим, 3 файла php. 1. head.php (шапка) (содержимое) <html><head>...

1
 Аватар для tarasalk
1992 / 1216 / 440
Регистрация: 13.06.2013
Сообщений: 4,115
03.05.2019, 10:19
Это же просто массив массивов, проходится в два цикла без всякой рекурсии.

Сначала собираете в удобный вид.
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
$arr = ['color' => [1], 'screen_size' => [2,22], 'brand' => [3,33,333]];
        
$result = [];
foreach ($arr as $property => $values) {
    foreach ($values as $i => $value) {
        $result[$i][$property] = $value;
    }
}
 
echo "<pre>"; print_r($result); echo "</pre>";
/**
Array
(
    [0] => Array
        (
            [color] => 1
            [screen_size] => 2
            [brand] => 3
        )
 
    [1] => Array
        (
            [screen_size] => 22
            [brand] => 33
        )
 
    [2] => Array
        (
            [brand] => 333
        )
 
)*/
Потом аналогично в два цикла собираете sql запрос. (это уж сами, без ORM мне лень )
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
03.05.2019, 10:19
Помогаю со студенческими работами здесь

Как сделать чтобы несколько групп по 10 человек между собой играли?
Добрый день, нужна ваша помощь, опишу проблему- есть сайт, человек заходит на сайт, регестрируется, переходит на вкладку играть, на...

Переставить между собой элементы массива между собой, кроме максимального
Переставить между собой элементы массива между собой, кроме максимального, программа в СИ

Как связать значения массивов между собой?
Не подскажите,как имея 2 массива Частот и Амплитуд одинаковой длины, выловить частоты из нужного диапазона (определить их порядковый номер)...

Как связать все элементы между собой и относительно вводимого значения
Здравствуйте, намечается последняя контрольная по делфи и мне срочно нужна помощь. Нужно создать программу , которая вычисляет стоимость...

Обменять между собой значения переменных
даны названия двух стран присвоить эти названия переменным величинам s1 s2, после чего обменять значение между собой


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20%
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru