Перейти к содержимому
Открыть в приложении

Удобный способ просмотра. Узнать больше.

Дизайн и модификация Invision Community

Полноэкранное приложение на главном экране с push-уведомлениями, медалями и многим другим.

Чтобы установить это приложение на iOS и iPadOS
  1. Нажмите иконку «Поделиться» в Safari
  2. Прокрутите меню и нажмите На экран «Домой».
  3. Нажмите Добавить в правом верхнем углу.
Чтобы установить это приложение на Android
  1. Нажмите меню из трёх точек (⋮) в правом верхнем углу браузера.
  2. Нажмите Добавить на главный экран или Установить приложение.
  3. Подтвердите, нажав Установить.
Русский язык для Invision Community 5

Как ограничить количество записей в таблице?

Здравствуйте.

 

Я тут не могу никак разобраться. Мне нужно, чтобы  таблицу загружалось максимум 8 записей из базы данных. Чтобы PHP при работе с базой данных остановил работу, сразу как достигнет 8 записей. Нужно что-то вроде LIMIT из MySQL, только для фреймфорка IPS. Посмотрел в исходниках много мест где используется Table Helpers, но не нашел нужной функции в классе.  Мой код, который выводит таблицу:

 

{{$table = new \IPS\Helpers\Table\Content('IPS\cms\Records2', $record->url());}}
{{$table->limit= 8;}}
{{$table->pages= 1;}}
{$table|raw}

Кто может подкинуть решение?

Рекомендованные сообщения

Попробуйте $table->count = 8;

  • Автор

Нет, не помогло. Я смотрел исходники класса Helpers\Table, и кажется там нет вообще. Походу, что-то с where придумывать, но в поисках более в стиле фреймворка IPS.

Изменено пользователем vinegredz

Ну хз, в документации указан limit как количество записей. Просто дальше будет пагинации.

Можно попробовать как-то убрать пагинацю или поиграть с $table->count

 

/**
 * @brief	Number of records to show
 */
public $limit = 25;

  • Автор

limit ограничивает количество записей на одной странице, но ощущение такое, что SQL запрос, который делается при таком параметре все равно переваривает всю таблицу (потому что генерирует пагинацию), а мне нужно, чтобы после нахождения 8 записей, база данных не напрягалась. А пагинацию можно спрятать с помощью CSS, например.

system/Helpers/Table/Content.php

		$this->count = $class::getItemsWithPermission( $where, $sortBy, NULL, $this->permCheck, $this->includeHiddenContent, 0, NULL, $this->joinContainer, $this->joinComments, $this->joinReviews, TRUE, $this->joins, ( $this->container ) ? $this->container : FALSE, TRUE, TRUE, TRUE, $this->showMovedLinks );
	$it = $class::getItemsWithPermission( $where, $sortBy, array( ( $this->limit * ( $this->page - 1 ) ), $this->limit ), $this->permCheck, $this->includeHiddenContent, 0, NULL, $this->joinContainer, $this->joinComments, $this->joinReviews, FALSE, $this->joins, ( $this->container ) ? $this->container : FALSE, TRUE, TRUE, TRUE, $this->showMovedLinks );
	$this->pages = ceil( $this->count / $this->limit );

В первой строке считается кол-во записей

Во второй выбираются сами записи (X штук на страницу)

В третьей считается кол-во страниц

Создайте аккаунт или войдите в него для комментирования

Аккаунт

Навигация

Поиск

Поиск

Настроить push-уведомления браузера

Chrome (Android)
  1. Нажмите на иконку замка рядом с адресной строкой.
  2. Нажмите Права доступа -> Уведомления.
  3. Измените свои настройки.
Chrome (компьютер)
  1. Нажмите на иконку замка в адресной строке.
  2. Выберите Настройки сайта.
  3. Найдите Уведомления и измените свои настройки.