Меню

ORM: получение информации о разделах инфоблока на D7, использование Bitrix\Iblock\SectionTable и пользовательских полей

Просмотров: 221

Задача: При работе с инфоблоками в Битрикс, часто возникает необходимость получать данные о разделах. Для этих целей можно использовать класс Bitrix\Iblock\SectionTable. Рассмотрим базовое использование этого класса, а также способ получения пользовательских полей разделов.

sect_orm.jpeg

Основное использование Bitrix\Iblock\SectionTable

Bitrix\Iblock\SectionTable предоставляет удобный способ получения данных о разделах инфоблока. Пример ниже демонстрирует, как можно получить все разделы конкретного инфоблока:

use Bitrix\Main\Loader;
use Bitrix\Iblock\SectionTable;

Loader::includeModule('iblock');

$IBLOCK_ID = 10; // ID инфоблока

$getSections = SectionTable::getList([
    'filter' => [
        'IBLOCK_ID' => $IBLOCK_ID // Указываем конкретный инфоблок
    ],
    'select' => [
        '*',
    ]
])->fetchAll();

foreach ($getSections as $getSection) {
    var_dump($getSection);
}

Этот код выполняет следующее:

  • Подключает модуль iblock через Loader::includeModule.
  • Указывает ID инфоблока для фильтрации.
  • Использует метод getList класса SectionTable, чтобы получить все разделы указанного инфоблока.
  • Перебирает массив разделов и выводит их содержимое с помощью var_dump.

Cтандартный класс SectionTable возвращает только основные поля разделов, такие как ID, NAME, CODE и другие. Пользовательские поля (например, UF_*) не доступны через этот класс.

Получение пользовательских полей раздела через ORM

Пользовательские поля разделов (поля с префиксом UF_) нельзя получить с использованием SectionTable. Для работы с ними существует пространство имен \Bitrix\Iblock\Model, которое предоставляет механизм единого управления свойствами инфоблоков.

Для получения данных пользовательских полей разделов можно использовать класс \Bitrix\Iblock\Model\Section. Пример ниже демонстрирует, как это сделать:

use Bitrix\Main\Loader;
use Bitrix\Iblock\Model\Section;

Loader::includeModule('iblock');

$IBLOCK_ID = 10; // ID инфоблока

$entitySections = Section::compileEntityByIblock($IBLOCK_ID);

$getSections = $entitySections::getList([
    'select' => [
        '*',        // Основные поля
        'UF_*'      // Пользовательские поля
    ],
])->fetchAll();

foreach ($getSections as $getSection) {
    var_dump($getSection);
}
  • Подключаем модуль iblock через Loader::includeModule.
  • Используем метод compileEntityByIblock класса Section, чтобы создать сущность разделов для указанного инфоблока.
  • С помощью метода getList получает как стандартные, так и пользовательские поля разделов.
  • Перебираем полученные данные и выводим их содержимое.

Подробно о \Bitrix\Iblock\Model\Section

Класс \Bitrix\Iblock\Model\Section входит в пространство имен \Bitrix\Iblock\Model и предоставляет расширенные возможности для работы с разделами инфоблоков. Основные преимущества:

  • Единое управление свойствами: Позволяет работать с пользовательскими полями, которые не доступны через стандартные ORM-классы.
  • Динамическая компиляция сущностей: Метод compileEntityByIblock создает ORM-сущность на основе структуры указанного инфоблока. Это дает возможность работать с пользовательскими полями, не создавая дополнительных классов.
  • Гибкость: Поддерживает выборку, фильтрацию и сортировку данных с учетом пользовательских полей.
use Bitrix\Main\Loader;
use Bitrix\Iblock\Model\Section;

Loader::includeModule('iblock');

$IBLOCK_ID = 15; // ID инфоблока

$entity = Section::compileEntityByIblock($IBLOCK_ID);

$sections = $entity::getList([
    'filter' => ['ACTIVE' => 'Y'],
    'select' => ['ID', 'NAME', 'UF_CUSTOM_FIELD'],
])->fetchAll();

foreach ($sections as $section) {
    echo "ID: {$section['ID']}, NAME: {$section['NAME']}, CUSTOM FIELD: {$section['UF_CUSTOM_FIELD']}\n";
}

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

Выбор подхода зависит от ваших потребностей и сложности задачи. Если вам нужно получить только стандартные поля разделов, то достаточно использовать SectionTable. Если же требуется работа с пользовательскими полями, рекомендуется использовать механизм из пространства имен \Bitrix\Iblock\Model

Михаил Базаров 07.01.2025
Метод ::getList класса Bitrix\Iblock\SectionTable, как и во всех (практически) классах D7 принимает параметры:
Код
$res = \Запрос\К нужному классу::getList([
    'order' => // массив- сортировка
    'select' => // массив- выбираемые поля
    'filter' => // массив- фильтр
    'group' =>  // массив- группировка, order должен быть пустой
    'limit' => // число- ограничение выбираемого кол-ва
    'offset' => // число- смещение первого столбца в результате
    'count_total' => // число- дает возможность получить кол-во элементов через метод getCount()
    'runtime' =>  // массив полей сущности, создающихся динамически
    'data_doubling' => // булево (ум. false) - получение одинаковых записей
    'cache' => array( // массив-  кеширование запроса запроса
        'ttl' => 1000,
        'cache_joins' => true
    ),
]);

Стоимость и сроки разработки сайтов и приложений

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

Интернет магазин: разработка с нуля от 400 000 руб.
от 5-ти недель

Cоздание интернет-магазина на 1С-Битрикс. Разработка с нуля, оптимизация кода под конкретный проект и требования. Реализация любого функционала без ограничений готовых решений.

Интернет-магазин на готовом решении от 100 000 руб.
от 7-ми дней

Готовое решение — вариант для тех, кто не хочет тратить много средств на индивидуальный проект, и не имеет серьезных требований к сайту. Запускается на одном из 200-та (на ваш выбор) готовых решений.

Мобильное приложение от 400 000 руб.
от 1-го месяца

Разработка кроссплатформенного мобильного приложения, которое не уступает нативным решениям как в производительности, так и пользовательском опыте. Публикуется в AppStore, GooglePlay и RuStore

Опросник на разработку. После ознакомления, задам уточняющие вопросы и оценю проект по стоимости и срокам разработки.