208 похожих чатов

Нужен совет тех, кто оптимизировал выборки. Есть ли подводные камни в

моем подходе?
Задача стояла в ускорение выборки элементов со свойствами и снижение потребления ресурсов сервером.


Подход из мануала по ORM
$promoIblock = \Bitrix\Iblock\Iblock::wakeUp($promoIblockId);
$elements = $promoIblock->getEntityDataClass()::getList([

Время выполнения: 0.149571
Память: 33 934 512

Ускоренный, но более громоздкий:
1. получаем все свойства ИБ (кеш 24 часа)
$ibProps = \Bitrix\Iblock\PropertyTable::getList([
2. получаем нужные элементы (кеш минута)
$arPromo = \Bitrix\Iblock\ElementTable::getList([
3. получаем значение свойств для элементов (кеш минута)
$properties = \Bitrix\Iblock\ElementPropertyTable::getList([
4. Разносим полученные свойства по нашим элементам

Время выполнения: 0.078432
Память 13 489 968

4 ответов

21 просмотр

Есть. Ваш код будет работать только для инфоблоков 1.0. Ну и всякие интересные артефакты вроде обработки значений пользовательских типов свойств и обработки списочных свойств

Антон (code-pilots)- Автор вопроса
Eugene Zhukov
Есть. Ваш код будет работать только для инфоблоков...

спасибо за коментарий. Тут как раз каталог на ИБ 1.0. А есть возможность перевести каталог на ИБ 2.0? Чет я пока таких не встречал за 2 года. Интересно было бы сравнить производительность.

Антон (code-pilots)
спасибо за коментарий. Тут как раз каталог на ИБ 1...

заходите в настройки инфоблока и меняете, если число свойств позволяет

Антон (code-pilots)- Автор вопроса
Eugene Zhukov
заходите в настройки инфоблока и меняете, если чис...

Это "изменить место хранения свойств"? Помню мне крайне не советовали это делать. Попробую на копии. Тут решение Аспро, посмотрим отвалится или нет.

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта