pagination - Yii2 Union 分页问题

标签 pagination yii2

我尝试在两个查询合并后使用分页,但分页似乎不起作用。但是,如果我尝试在没有联合的情况下进行一个查询,它就会起作用。 以下是疑问,请帮忙。

//First Query
$first_second = $this->find()->select($strcolumn.', p.featured_name')->from(MYDIRECTORY::tableName().' j')->join('INNER JOIN' ,MYDIRECTORYFEATUREDCLASS::tableName().' p', 'p.featurer_id = j.listdetails_featured_frid')->where(['listdetails_list_frid' => $id['list_id']])->andWhere(['<=', 'listdetails_featured_frid', 2])->andWhere(['listdetails_list_flag' => MYDIRECTORYCLASS::STATUS_ACTIVE])->orderBy(['listdetails_featured_frid'=>SORT_ASC,'listdetails_list_pos'=>new Expression('rand()')]);

 //Second Query
$second_list =  $this->find()->select($strcolumn.', p.featured_name')->from(MYDIRECTORYCLASS::tableName().' j')->join('INNER JOIN' ,MYDIRECTORYFEATUREDCLASS::tableName().' p', 'p.featurer_id = j.listdetails_featured_frid')->where(['listdetails_list_frid' => $id['list_id']])->andWhere(['>', 'listdetails_featured_frid', 2])->andWhere(['listdetails_list_flag' => MYDIRECTORYCLASS::STATUS_ACTIVE])->orderBy(['listdetails_featured_frid'=>SORT_ASC,'listdetails_list_medname'=>SORT_ASC]);


//Joined Union Query
$joinedquerys=$first_second->union($second_list);

$countQuery = clone $joinedquerys;

$pages = new Pagination(['totalCount' => $countQuery->count(), 'pageSize' => \Yii::$app->params['pagination_limit'],'defaultPageSize' => \Yii::$app->params['pagination_limit'],'forcePageParam' => false,'params' => ['page' => \Yii::$app->request->get('page', 1)] ]);

$resultArray = $joinedquerys->offset($pages->offset)->limit($pages->limit)->asArray()->all();


return $this->render('listing', [
            "mylisting" =>  $resultArray,
            "pagination" => $pages
]);

使用如下分页时,分页似乎不起作用?任何帮助将不胜感激

echo LinkPager::widget([
                    'pagination' => $pagination,
                    'options' => ['class' => 'paginate pag2 clearfix'],
                    'registerLinkTags' => true,
                    'prevPageLabel' => \YII::$app->params['linker_page_btn_prev'],
                    'nextPageLabel' => \YII::$app->params['linker_page_btn_next'],
                    'maxButtonCount' => \YII::$app->params['linker_page_btn_count'],
                    'activePageCssClass' => 'current',
                     'nextPageCssClass' => 'next'
]);

最佳答案

你可以使用 dataProvider

<?php


  $joinedquerys=$first_second->union($second_list);



  $dataProvider = new SqlDataProvider([
    'sql' => $joinedquerys,

  ]);

?>

关于pagination - Yii2 Union 分页问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37985257/

相关文章:

jquery - tablesorter 分页不会在初始页面加载时排序

php - Html::error 似乎不适用于 ajaxValidation 或 clientsidevalidation

php - YII2中如何输出数据?

php - 在 jQuery 中将项目设置为数组并传递给 PHP

css - 添加内容第 nth-child 到分页

php - 分页问题 [PHP]

php - 如何在 Codeigniter 的分页类中隐藏页面链接?

yii2 - 没有数据库的 UserIdentity 中的 Yii 2.0 身份验证

php - MySql Yii2 如何显示单元格值?

javascript - bootpag 事件在返回的 Ajax 函数之后使用时会运行多次