【问题标题】:Laravel union and join in the queryLaravel 联合并加入查询
【发布时间】:2019-10-17 15:19:28
【问题描述】:

我有 3 张桌子

  1. send_to_employees
  2. onprocess
  3. 员工

我想合并两个表send_to_employeesonprocess。之后我想用employees 表加入结果。

我已经在原始 SQL 查询中完成了,如下所示:

SELECT * 
FROM (
  SELECT
    send_to_employees.caseid,
    send_to_employees.docs,
    send_to_employees.helper,
    send_to_employees.employee_id 
  FROM send_to_employees
  UNION
  SELECT
    onprocess.caseid, 
    onprocess.docs, 
    onprocess.helper, 
    onprocess.employee_id
  FROM onprocess
) t1 
INNER JOIN employees 
  ON employees.employee_id = t1.employee_id

但我不知道如何使用 Laravel 来做到这一点。请帮助我使用 Laravel 5.8 的查询生成器编写此查询。

【问题讨论】:

  • 如果您可以共享表格描述以及预期的结果格式。

标签: laravel laravel-query-builder laravel-5.8


【解决方案1】:

试试这个代码 sn-p。我认为它应该工作。我正在使用查询生成器

//获取表中的所有记录

 $data['recorddisplay'] = DB::table('send_to_employees')
 ->leftjoin('onprocess', 'send_to_employee.caseid', '=', 'onprocess.caseid')
 ->leftjoin('employees', 'send_to_employee.employee_id', '=', 'employees.employee_id')
 ->get();

【讨论】:

  • 你也可以试试只加入而不是左加入
【解决方案2】:

你正在寻找的是这样的:

DB::query()
    ->fromSub(
        DB::table('send_to_employees')
            ->select([
                'caseid',
                'docs',
                'helper',
                'employee_id'
            ])
            ->union(
                DB::table('onprocess')
                    ->select([
                        'caseid',
                        'docs',
                        'helper',
                        'employee_id'
                    ])
            ),
        'inner'
    )
    ->join('employees', 'employees.employee_id', '=', 'inner.employee_id')
    ->select(['inner.*', 'employees.*'])
    ->get();

成功的关键是使用fromSub(),它允许您执行子查询。请确保不要在子查询中使用->get(),因为它会包装集合并因此失败。

【讨论】:

  • 你真的很棒,先生。太感谢了。喜欢它。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2017-11-20
  • 1970-01-01
  • 2019-01-28
  • 1970-01-01
  • 1970-01-01
  • 2023-04-09
  • 2016-11-06
相关资源
最近更新 更多