1
我需要做两个不同的集合分页。有优先上市。放在优先列表中的资金。Laravel合并2集合与paginator
为什么你不做单个查询,你可以说优先级列表。原因,当使用过滤;城市,县,我选择的类别。但是,网站所有者需要在城市,县,甚至是您想要的类别中列出的优先领域中优先列出。
因此,在使用3个标准的查询关键字时,其他标准在第一个标准中就足够了。每个页面列出20条记录,如果30个第一列表的主要列表,另一个列表中的第二个记录集合我想在此后列出。
根据标准通常与你现在我分享我的代码。等待你的建议。先谢谢你。
对不起我的英语不好。
DB::table('UserAds')
->join('Ads', 'Ads.id', '=', 'UserAds.ad_id')
->join('Users', 'Users.id', '=', 'UserAds.user_id')
->join('AdCategory', 'AdCategory.ad_id', '=', 'Ads.id')
->join('AdEducationPrices', 'AdEducationPrices.ad_id', '=', 'Ads.id')
->join('City', 'City.id', '=', 'Ads.city_id')
->join('Town', 'Town.id', '=', 'Ads.town_id')
->leftJoin('AdMedias', 'AdMedias.ad_id', '=', 'Ads.id')
->select('Ads.*', 'AdEducationPrices.*', 'City.name as city_name', 'City.id as city_id',
'Town.name as town_name', 'Town.id as town_id', 'AdMedias.url')
->where('Ads.is_publish', 1)
->whereIn('AdCategory.category_id', $new_category_array)
->where('Ads.city_id', $city_id)
->where('Ads.town_id', $town_id)
->where('UserAds.is_purchased', true)
->where('UserAds.started_at', '<', date('Y-m-d H:i:s'))
->where('UserAds.finished_at', '>=', date('Y-m-d H:i:s'))
->where('AdMedias.type', 'picture')
->groupby('UserAds.ad_id')->orderby('finished_at', 'DESC')
->orderby('started_at', 'DESC')->paginate(20);