В старом ядре Bitrix (не D7) запросы к базе данных часто строились с использованием CDatabase::GetList и рядом прямо указыванных параметров. В коде D7 (новое ядро Bitrix) для работы с базой данных и сущностями предназначен класс `\Bitrix\Main\ORM\Query\Query` или предопределенные методы из класса Entity.
Вот некоторые из ключевых аспектов перевода запроса на D7:
1. Вместо функций типа `CIBlockElement::GetList` используются Entity-объекты и Query-объекты.
2. Конструкции типа `array("nPageSize" => ..., "iNumPage" => ...)` заменяются на параметры `limit` и `offset` у Query-объекта.
3. Параметры фильтрации и сортировки передаются через методы `setFilter`, `setOrder`, и так далее.
Непосредственно ваш запрос будет выглядеть следующим образом в D7:
```php
use Bitrix\Main\Loader;
use Bitrix\Main\ORM\Query\Query;
use Bitrix\Iblock\IblockTable;
Loader::includeModule('iblock');
// Это пример, где $iblockId - ID вашего инфоблока, $nPageSize - количество элементов на странице, $iNumPage - номер страницы
$iblockId = 1; // Пример ID инфоблока
$nPageSize = 50; // Количество элементов на странице
$iNumPage = 1; // Номер страницы
// Узнаем класс сущности вашего инфоблока
$iblockClass = IblockTable::compileEntity($iblockId)->getDataClass();
// Построение запроса
$query = new Query($iblockClass::getEntity());
$query->setSelect(['*']) // Выбираем все поля или укажите необходимые поля массивом
->setFilter(['IBLOCK_ID' => $iblockId]) // Условия фильтрации
->setOrder(['SORT' => 'ASC']); // Условия сортировки
// Пагинация
$query->setOffset(($iNumPage - 1) * $nPageSize)->setLimit($nPageSize);
// Получение результатов запроса
$resultSet = $query->exec();
// Итерация по результатам
while ($item = $resultSet->fetch()) {
// Обработка каждого элемента
}
```
Замечу, что код D7 приведенный выше является лишь примером и требует адаптации под конкретные потребности и структуру вашей базы данных. Вы должны изменить `setSelect`, `setFilter`, `setOrder` и другие методы согласно вашим требованиям.
Ответ относительно `false` для `nTopCount` и `checkOutOfRange` в вашем вопросе: в D7 вы просто не используете логику, отвечающую за эти параметры, если она вам не нужна. Объект Query в D7 дает вам гибкость конфигурировать запросы более детально и непосредственно.