group by和union,Laravel分页
$res3 = DB::table('users')
->join('user_folow_boutiques', 'user_folow_boutiques.user_id', '=', 'users.id')
->join('boutique', 'boutique.id', '=', 'user_folow_boutiques.boutique_id')
->join('type_article', 'type_article.boutique_id', '=', 'boutique.id')
->join('article', 'type_article.id', '=', 'article.type_article_id')
->join(DB::raw('(SELECT article.id c_id, count(user_aime_article.id) as nbrlik FROM article JOIN user_aime_article on user_aime_article.article_id = article.id GROUP BY user_aime_article.article_id) e'),'article.id','=','e.c_id')
->where('users.id','=',$user_id)
->where('e.nbrlik','=',50)
->select(DB::raw('article.*,article.created_at as date, e.nbrlik'))
->union($res)
->union($res2)
->groupBy('article.id')
->orderBy('date','DESC');
$sql = $res3->toSql(); $result = \DB::table(\DB::raw("($sql) as a"))->mergeBindings($res3)
->Paginate(10);
public static function getActu($user_id,$page){
$paginate = 5;
// 1 selectionnée tous les article publier par les shop suivi
$res = DB::table('users')
->join('user_folow_boutiques', 'user_folow_boutiques.user_id', '=', 'users.id')
->join('boutique', 'boutique.id', '=', 'user_folow_boutiques.boutique_id')
->join('type_article', 'type_article.boutique_id', '=', 'boutique.id')
->join('article', 'type_article.id', '=', 'article.type_article_id')
->where('users.id','=',$user_id)
->select(DB::raw('article.*,article.created_at as date,null as nbrlik')); // 2 Selectionnée tous les produit amai par les utilisateur suivit Arevoir demain
$res2 = DB::table('users')
->join('user_follow_user', 'user_follow_user.user_id_1', '=', 'users.id')
->join('user_aime_article', 'user_follow_user.user_id_2', '=', 'user_aime_article.user_id')
->join('article', 'user_aime_article.article_id', '=', 'article.id')
->where('users.id','=',$user_id)
->select(DB::raw('article.*,user_aime_article.created_at as date, null as nbrlik') )
->distinct();
// Selectioner tous les proiduit des boutique suivi par le user qui ont 50 j'aime
$res3 = DB::table('users')
->join('user_folow_boutiques', 'user_folow_boutiques.user_id', '=', 'users.id')
->join('boutique', 'boutique.id', '=', 'user_folow_boutiques.boutique_id')
->join('type_article', 'type_article.boutique_id', '=', 'boutique.id')
->join('article', 'type_article.id', '=', 'article.type_article_id')
->join(DB::raw('(SELECT article.id c_id, count(user_aime_article.id) as nbrlik FROM article JOIN user_aime_article on user_aime_article.article_id = article.id GROUP BY user_aime_article.article_id) e'),'article.id','=','e.c_id')
->where('users.id','=',$user_id)
->where('e.nbrlik','=',50)
->select(DB::raw('article.*,article.created_at as date, e.nbrlik'))
->union($res)
->union($res2)
->groupBy('article.id')
->orderBy('date','DESC')
->skip($paginate * ($page - 1) )->take($paginate)->get();
return $res3;
}
group by和union,Laravel分页的更多相关文章
- Laravel 分页详解
Laravel分页很简单,但功能又很强大噢! 首先在控制器的方法中使用paginate(页面显示条数)方法,传入页面显示的条数 然后在模板页面使用方法render()来生成html元素 appends ...
- group By 和 Union 、 Union all的用法
我学习的是MySQL,学习写sql语句过程中遇到Group By 和 Union. 大家乐意看这两个链接,写的很好 Group By: www.cnblogs.com/rainman/archive/ ...
- php laravel加密 form表单认证 laravel分页
use Illuminate\Support\Facades\Crypt; echo Crypt::encrypt(123); //加密echo "<br>";//解密 ...
- laravel 分页
因为Laravel默认使用的是en语言文件所有咱们相应使用中文分页提示的话,可以按如下步骤操作: laravel4------------------------------------------- ...
- Laravel分页
Laravel使用的过程中,有些功能把前端页面的表达"写死了",比如分页的翻页按钮! 当然你会说Laravel的Bootstrap样式也很好看啊,但是实际项目中,翻页按钮常常需要满 ...
- laravel 分页和共多少条 加参数的分页链接
<div class="pagers "> <span class="fs pager">共 {{$trades->total() ...
- laravel 分页使用
分页 //对数据库结果分页 $users = DB::table('users')->paginate(15); //可以对 Eloquent 模型分页: $allUsers = User::p ...
- Laravel 分页 数据丢失问题解决
问题: to do list 中有32条数据,每页10条,共3页. 做完了一个事项之后,准备打卡,发现找不到这个事项. 数据库查询正常,有这一条数据. 原因: 发现是分页出了问题,第1页的数据和第2页 ...
- 为laravel分页样式制定class
做的项目有一个上翻页和下翻页,使用了框架提供的
- Laravel分页带参数的实现方法
控制器: $data['type'] = 5;$data['member_list'] = Member::orderBy('id', 'desc')->paginate(10);return ...
随机推荐
- 058_Component Bundles
- 【七侠传】冲刺阶段--Day7
[七侠传]冲刺阶段--Day7 团队成员 20181221曾宇涛 20181202李祎铭 20181209沙桐 20181215薛胜瀚 20181216杨越麒 20181223何家豪 20181232 ...
- 在Unity3D中开发的Hologram Shader
SwordMaster Hologram Shader 特点 此全息投影风格的Shader是顶点片元Shader,由本人手动编写完成 此全息投影风格的Shader已经在移动设备真机上进行过测试,可以直 ...
- JavaScript 之 数组在内存中的存储方式(连续或不连续)
最近在纠结一个问题,就是数组这个引用类型在JavaScript 中是不是和其他语言一样开辟了一个连续的内存来存储,但是在JS 中每个元素又可以是不同的类型,这就导致了没办法用一个相同大小的存储,所以数 ...
- mysqld 打开连接卡
把client的ip写在mysql服务器的/etc/hosts文件里 echo [ip] [hostname] >>/etc/hosts
- Ubuntu linux下gcc、g++不同版本的安装和切换
讲解linux下gcc.g++不同版本的安装和切换 Ubuntu 18.04预装GCC版本为7.3,但有时在编译是需要用的不同gcc版本,下面介绍,如何安装不同的gcc 和g++,并设置根据不同的需要 ...
- Mysql 字段加密
1.PASSWORD() 2.ENCODE(,) DECODE(,) 3.MD5()4.SHA5() 5.AES_ENCRYPT AES_DECRYPT 加密 select aes_encry ...
- window.location.href 下载文件页面出现跳转 (重定向失效的问题)
页面出现跳转的话,要去检查请求的接口是不是出现了问题. 解决方法:URL前面加 "/" ${process.env.VUE_APP_BASE_API} / ${url}
- 初步学习UE网络同步
UE 网络同步和框架介绍 为一个UE引擎的初学者基于现有知识储备和见识的限制下,对UE网络和游戏框架的粗鄙之见,文中多有错误敬请指出以较后文. 1.网络复制 不论是服务端还是客户端,代码都是一样的 ...
- deepin 调整微信、百度网盘、迅雷等等软件字体的方法
一.修改微信字体大小方法: 1.方法一:修改deepinwine桌面环境字体 env WINEPREFIX="$HOME/.deepinwine/Deepin-WeChat" wi ...