С Новым годом! Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/6: Рейтинг темы: голосов - 6, средняя оценка - 4.50
 Аватар для Mashka_mulashka
25 / 25 / 11
Регистрация: 13.12.2011
Сообщений: 818

Как можно оптимизировать тройной вложенный цикл и запрос к БД

20.10.2016, 17:00. Показов 1355. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
на входе 3 массива

1-й $arResult['PLAYERS'], содержит массив из ID команд, которые в свою очередь содержат массив ID игроков

выглядит вот так

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
33
34
35
36
37
38
39
40
Array
(
    [1] => Array
        (
            [ID] => Array
                (
                    [0] => 17
                    [1] => 18
                    [2] => 19
                    [3] => 20
                    [4] => 21
                    [5] => 22
                    [6] => 23
                    [7] => 25
                    [8] => 26
                    [9] => 27
                    [10] => 28
                    [11] => 29
                    [12] => 30
                    [13] => 31
                    [14] => 32
                    [15] => 33
                    [16] => 34
                    [17] => 35
                    [18] => 36
                    [19] => 37
                    [20] => 38
                    [21] => 39
                    [22] => 40
                    [23] => 41
                    [24] => 42
                    [25] => 43
                    [26] => 44
                    [27] => 45
                    [28] => 59540
                    [29] => 60153
                    [30] => 59541
                )
 
        )
и т.д. всего 16 ID команд.

второй массив - $arResult['CHAMPS'] - массив чемпионатов. Содержит массив чемпионатов, их ID и названия

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
     
 
Array
(
    [0] => Array
        (
            [ID] => 1845
            [NAME] => Чемпионат «Интер РАО»
        )
 
    [1] => Array
        (
            [ID] => 1868
            [NAME] => Кубок «Интер РАО»
        )
 
    [2] => Array
        (
            [ID] => 1869
            [NAME] => Турнир имени Г.Ю. Волгина
        )
 
)
сам запрос выглядит вот так

PHP
1
2
3
4
5
6
7
8
9
foreach($arResult['PLAYERS'] as $team_id => $team_arr){
    foreach($team_arr['ID'] as $player_id){
        foreach($arResult['CHAMPS'] as $champ){
            $champ_id = $champ['ID'];
            $players[$team_id][$player_id][$champ_id] = Players::GetFiveNumber($player_id, $champ_id);
            $players[$team_id][$player_id]['PLAYER_NAME'] = Players::GetInfo($player_id)['NAME'];
        }
    }
}
метод Players::GetFiveNumber делает следующее. Получает Номер пятерки игрока в определенном туре определенного чемпионата, а затем выдает итоговый массив вида

PHP
1
2
3
4
5
6
array = (
    [0] => array(
      ['ID'] => ID заявки игрока на тур
      ['FIVE_NUMBER'] => номер пятерки, в которой игрок учавствовал в этом туре
    );
);
всего элементов по каждому игроку от 10 до 12

код метода
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
    public static function GetFiveNumber($p_id, $c_id){
        $res = CIBlockElement::GetList(
            array('PROPERTY_BID_TEAM.PROPERTY_TOUR_BID' => 'ASC'),
            array("IBLOCK_ID"=>IBLOCK_BID_PLAYER_MATCH, "PROPERTY_BID_CHAMP.ID" => $c_id, "PROPERTY_BID_PLAYERID.ID" => $p_id),
            false,
            false,
            array("ID","NAME","PROPERTY_BID_NUMBER_OF_FIVE")
        );
 
        $tours = Championship::GetAllTours();
        while($ob = $res->GetNextElement()){
                $arFields[] = $ob->GetFields();
        }
 
        $tmp = array();
        foreach($arFields as $bid){
            $tmp[$bid['PROPERTY_BID_TEAM_PROPERTY_TOUR_BID_VALUE']] = $bid;
        }
 
 
        $res = array();
        foreach($tours as $tour_key => $tour_val){
            if($tour_val == $tmp[$tour_val]['PROPERTY_BID_TEAM_PROPERTY_TOUR_BID_VALUE']){
                $res[$tour_key] = $tmp[$tour_val];
            }else{
                $res[$tour_key] = 'empty';
            }
        }
 
        return $res;
    }
для тех, кто не знаком с битриксом, GetList отправляет запрос в БД.

метод Players::GetInfo так же GetList`ом достает имя игрока из БД.

вопрос - как оптимизировать такое? всего элементов около 800 и пополняется на 200-300 каждый месяц. Загрузка страницы идет примерно от 40 секунд до 1,5 минут
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
20.10.2016, 17:00
Ответы с готовыми решениями:

Тройной вложенный запрос
Подскажите как объединить вот такие три запроса: Select Phone from AllBase where Phone= '22222222'"; INSERT INTO AllBase...

Тройной вложенный запрос/запрос из трех таблиц
Добрый день, помогите, пожалуйста, правильно составить sql запрос. Есть три таблицы: 1. Список лекций, ключевое поле код лекции, также...

Как можно оптимизировать запрос?
Подскажите пожалуйста, можно ли как то объединить эти три запроса в один ? SELECT brand, count(*) as num FROM food where type =...

2
wq
85 / 78 / 32
Регистрация: 26.11.2015
Сообщений: 481
20.10.2016, 19:01
Цитата Сообщение от Mashka_mulashka Посмотреть сообщение
вопрос - как оптимизировать такое
изучить основы программирования. За запрос к базе внутри 3х кратного цикла выгоняют из университета или с работы(если вам удалось хитростью на неё поступить).Все пишется одним sql запросом
курсы сами знаете сколько стоят. Для битрикщиков вариант один: твердите начальству, что железо устарело
1
 Аватар для Mashka_mulashka
25 / 25 / 11
Регистрация: 13.12.2011
Сообщений: 818
21.10.2016, 10:49  [ТС]
Цитата Сообщение от wq Посмотреть сообщение
изучить основы программирования. За запрос к базе внутри 3х кратного цикла выгоняют из университета или с работы(если вам удалось хитростью на неё поступить).Все пишется одним sql запросом
да понятно, блин, что выгоняют. Собственно, поэтому тема тут и появилась)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
21.10.2016, 10:49
Помогаю со студенческими работами здесь

Можно ли как то оптимизировать sql запрос
Вопрос насущный. Столкнулся с такой проблемой, есть большой запрос, который делает некоторую выборку из разных таблиц с большим кол-вом...

Как можно оптимизировать запрос выборки по двум датам из БД Sqlite?
Составил запрос по выборки максимальных значений из двух полей с датами, используя несколько связанных таблиц: SELECT...

Вложенный запрос вернул больше одного значения Это запрещено, когда вложенный запрос следует после =, !=, <
Здравствуйте,проблема вот в чем,при добавление записи в таблицу,первая запись добавляется,а при добавление второй выдает что...

Вложенный запрос вернул больше одного значения Это запрещено, когда вложенный запрос следует после =, !=, <, <
Здравствуйте,проблема вот в чем,при добавление записи в таблицу,первая запись добавляется,а при добавление второй выдает что...

Как переделать данный цикл for во вложенный цикл foreach?
Добрый день, как переделать данный цикл во вложенный цикл foreach? for (i in 0 until fieldPos.size) { for (j in 0...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru