关于laravel 子查询 & join的使用


Posted in PHP onOctober 16, 2019

本项目中关联了2个数据库

'default' => env('DB_CONNECTION', 'mysql'), //默认使用mysql为连接库

'connections' => [

  'mysql' => [
   'driver' => 'mysql',
   'host'  => '192.168.0.xx',
   'database' => 'database',
   'username' => 'root',
   'password' => '',
   'charset' => 'utf8',
   'collation' => 'utf8_unicode_ci',
   'prefix' => 'tb_',
   'strict' => false,
  ],

  'mysql_snapshot' => [
   'driver' => 'mysql',
   'host'  => env('DB_HOST_SNAPSHOT', '192.168.0.xx'),
   'database' => env('DB_DATABASE_SNAPSHOT', 'snapshot'),
   'username' => env('DB_USERNAME_SNAPSHOT', 'root'),
   'password' => env('DB_PASSWORD_SNAPSHOT', ''),
   'charset' => 'utf8',
   'collation' => 'utf8_unicode_ci',
   'prefix' => 'tb_',
   'strict' => false,
  ],
 ],

在某个需求中,需要使用子查询获取snapshot快照表库的关联数据,从而实现以下sql逻辑

SELECT ... From
 (SELECT
  sum(game_count) AS sum_count,
  max(game_count) AS max_count,
  game_room_id,
  record_date
 FROM
  `tb_xx_snapshot`
  WHERE
  record_date BETWEEN '2017-05-17' AND '2017-05-23'
  AND 
  type = '1'
  GROUP BY 
  game_room_id) as main
INNER JOIN `tb_xx_snapshot` AS `tb_gg` ON tb_gg.game_count = main.max_count and tb_gg.game_room_id = main.game_room_id
where
 tb_gg.record_date BETWEEN '2017-05-17' AND '2017-05-23'
AND 
 tb_gg.type = '1'
GROUP BY 
 tb_gg.game_room_id;

其中子查询主要用到以下query builder语句

$query = DB::table('xx_snapshot')->where('xx','yy')->groupBy('xx');
$main = DB::connection('mysql_snapshot')
  ->table(DB::raw("({$query->toSql()}) as tb_main"))
  ->mergeBindings($query->getQuery()) // 绑定参数,否则sql语句会只有'?'
  ->get();

而join语句中可传入匿名函数重新构造,如再其中加多几个连接条件,或者查询条件

$con = DB::table('xx_snapshot')
  ->join('xx_snapshot as gg', function ($query) {
    $query->on('gg.game_count', '=', 'xx_snapshot.max_count')
     ->on('gg.game_room_id', '=', 'xx_snapshot.game_room_id')
     ->where('gg.xx','123';
   })

实现上述需求完整代码如下:

$subQuery= GameroomModel::select(DB::raw('sum(game_count) as sum_count,max(game_count) as max_count,record_date,game_room_id'))   
    ->whereBetween('record_date',[$beginDay,$endDay])
    ->where('type','1')
    ->groupBy('game_room_id');

$main = DB::connection('mysql_snapshot')
  ->table(DB::raw("({$subQuery->toSql()}) as tb_main"))
  ->mergeBindings($playerGame->getQuery())
  ->join('gameroom_snapshot as gg', function ($join) {
   $join->on('gg.game_count', '=', 'main.max_count')
     ->on('gg.game_room_id', '=', 'main.game_room_id');
  })
  - >select('main.max_count','main.sum_count','gg.record_date','main.game_room_id')
  ->whereBetween('gg.record_date',[$beginDay,$endDay])
  ->groupBy('main.game_room_id')
  ->get();

代码中子查询和外层都group by了一次,应该可以再优化一下.

以上这篇关于laravel 子查询 & join的使用就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
PHP自动生成月历代码
Oct 09 PHP
Optimizer与Debugger兼容性问题的解决方法
Dec 01 PHP
php入门教程 精简版
Dec 13 PHP
php中的filesystem文件系统函数介绍及使用示例
Feb 13 PHP
基于PHP代码实现中奖概率算法可用于刮刮卡、大转盘等抽奖算法
Dec 20 PHP
php 伪造HTTP_REFERER页面URL来源的三种方法
Sep 22 PHP
php is_executable判断给定文件名是否可执行实例
Sep 26 PHP
PHP  Yii清理缓存的实现方法
Nov 10 PHP
详解PHP函数 strip_tags 处理字符串缺陷bug
Jun 11 PHP
yii2中LinkPager增加总页数和总记录数的实例
Aug 28 PHP
PHP7 参数处理机制修改
Mar 09 PHP
详解php中流行的rpc框架
May 29 PHP
laravel高级的Join语法详解以及使用Join多个条件
Oct 16 #PHP
Laravel 连接(Join)示例
Oct 16 #PHP
Thinkphp 在api开发中异常返回依然是html的解决方式
Oct 16 #PHP
PHP 代码简洁之道(小结)
Oct 16 #PHP
解决tp5在nginx下修改配置访问的问题
Oct 16 #PHP
Laravel6.2中用于用户登录的新密码确认流程详解
Oct 16 #PHP
PHP实现15位身份证号转18位的方法分析
Oct 16 #PHP
You might like
PHP解码unicode编码的中文字符代码分享
2014/08/13 PHP
PHP会话控制:Session与Cookie详解
2014/09/27 PHP
animate动画示例(泪奔的小孩)及stop和delay的使用
2013/05/06 Javascript
nodejs中使用monk访问mongodb
2014/07/06 NodeJs
js立即执行函数: (function ( ){})( ) 与 (function ( ){}( )) 有什么区别?
2015/11/18 Javascript
深入浅析JavaScript的API设计原则
2016/06/14 Javascript
KVM虚拟化技术之使用Qemu-kvm创建和管理虚拟机的方法
2016/10/05 Javascript
利用fecha进行JS日期处理
2016/11/21 Javascript
AngularJS实现的回到顶部指令功能实例
2017/05/17 Javascript
图文介绍Vue父组件向子组件传值
2018/02/17 Javascript
仿vue-cli搭建属于自己的脚手架的方法步骤
2019/04/17 Javascript
jQuery实现高级检索功能
2019/05/28 jQuery
Vue监听页面刷新和关闭功能
2019/06/20 Javascript
解决layui的input独占一行的问题
2019/09/10 Javascript
JavaScript实现拖拽功能
2020/02/11 Javascript
Vue单页面应用中实现Markdown渲染
2021/02/14 Vue.js
[01:32]2014DOTA2西雅图邀请赛 CIS我们有信心进入正赛
2014/07/08 DOTA
使用Python脚本操作MongoDB的教程
2015/04/16 Python
requests和lxml实现爬虫的方法
2017/06/11 Python
pandas数据集的端到端处理
2019/02/18 Python
解决django model修改添加字段报错的问题
2019/11/18 Python
Python如何省略括号方法详解
2020/03/21 Python
python主要用于哪些方向
2020/07/05 Python
Python QTimer实现多线程及QSS应用过程解析
2020/07/11 Python
字中字效果的实现【html5实例】
2016/05/03 HTML / CSS
HTML5 manifest离线缓存的示例代码
2018/08/08 HTML / CSS
生物化工工艺专业应届生求职信
2013/10/08 职场文书
平安建设实施方案
2014/03/19 职场文书
新春文艺演出主持词
2014/03/27 职场文书
求职自荐信的格式
2014/04/07 职场文书
蟋蟀的住宅教学反思
2014/04/26 职场文书
判缓刑人员个人思想汇报
2014/10/10 职场文书
2015年清明节网上祭英烈留言寄语
2015/03/04 职场文书
大客户经理岗位职责
2015/04/09 职场文书
2015年企业工作总结范文
2015/04/28 职场文书
范文之农村基层党建工作报告
2019/10/24 职场文书