Jump to content
Дизайн и модификация IPS Community IPBSkinsBETA
Search In
  • More options...
Find results that contain...
Find results in...
Sign in to follow this  
vinegredz

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

Recommended Posts

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

 

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

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

Share this post


Link to post
Share on other sites

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

Share this post


Link to post
Share on other sites

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

Edited by vinegredz

Share this post


Link to post
Share on other sites

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

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

 

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

Share this post


Link to post
Share on other sites

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

Share this post


Link to post
Share on other sites

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

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

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
Sign in to follow this  

  • Recently Browsing   0 members

    No registered users viewing this page.

×
×
  • Create New...