Jump to content
View in the app

A better way to browse. Learn more.

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

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

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

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

 

Я тут не могу никак разобраться. Мне нужно, чтобы  таблицу загружалось максимум 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}

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

Featured Replies

  • Author

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

Edited by vinegredz

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

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

 

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

  • Author

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 штук на страницу)

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

Create an account or sign in to comment

Recently Browsing 0

  • No registered users viewing this page.

Account

Navigation

Search

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.