Как я могу сделать нумерацию данных HABTM? - PullRequest
0 голосов
/ 20 апреля 2009

У меня есть таблица, в которой у Коллекции есть много Сущностей, а у Сущности есть и принадлежит ко многим совокупностям. Теперь для конкретной коллекции есть много сущностей. Как я могу разбить на страницы эти сущности, принадлежащие к определенной коллекции. *

мой запрос на поиск говорит .., $ this-> Collection-> find ('first', array ('condition' => array ('uid' => $ uid)), 'Содержит (массив (' Объект '))); Теперь, как разбить результат на сущности ..

Ответы [ 2 ]

2 голосов
/ 27 апреля 2009

В вашем контроллере действие

$ this-> paginate = array ('Entity' => array ( 'condition' => "Entity.collection_id = $ id", 'fields' => array ('Entity. *') ) );

$ this-> set ('entity', $ this-> paginate ($ this-> Collection-> Entity));

1 голос
/ 20 апреля 2009

Я предполагаю, что вы используете базу данных SQL.
Сейчас я не тестировал код, но думаю, что он должен работать.

// First query to get some info.
$testquery = mysql_query("SELECT * FROM `table` WHERE `entity` = 'something'");
    if(!$testquery) die(mysql_error());

$total_items      = mysql_num_rows($testquery);     // Count the total number of entity's that match the criteria.  
$limit            = 10;     // Maximun number of entity's on page.
$page             = $_GET['page'];

//calcuate total pages
$total_pages     = ceil($total_items / $limit); // ceil is used to round up fractions to the next int
$set_limit          = $page * $limit - ($limit);


$query2 = mysql_query("SELECT * FROM `table` WHERE `entity` = 'something' LIMIT $set_limit, $limit");
    if(!$query2) die(mysql_error());


//show data matching query:
while($code = mysql_fetch_object($query2)) {
    echo("item: ".$code->title."<BR>");
}


// This displays the "previous page" link if there is a previous page.
$prev_page = $page - 1;
if($prev_page >= 1) {
    echo("<a href=yourpagename.php?page=$prev_page>Previous</a>");
}


//Display middle pages: 
$mid_page = 1;
while ($total_pages >= $mid_page) {
    if ($page == $midpage){
        echo ("<b>$mid_page</b> | ");
    }
    else {
        echo ("  <a href=yourpagename.php?page=$mid_page> $mid_page </a> | ");
        $midpage++;
    }
}

// This page will display a "next page" link if there is one.
$next_page = $page + 1;
if($next_page <= $total_pages) {
    echo("<a href=yourpagename.php?page=$next_page>Next</a>");
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...