Laravel 合并并加入查询
Laravel union and join in the query
我有 3 table
- send_to_employees
- 进程中
- 员工
我想合并 table send_to_employees
和 onprocess
这两个。之后我想将结果与 employees
table.
我已经在原始 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.
的查询生成器编写此查询
试试这个代码片段。我认为它应该工作。我正在使用查询生成器
//从table
获取所有记录
$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();
你要找的是这样的:
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()
,因为它会包装一个集合并因此失败。
我有 3 table
- send_to_employees
- 进程中
- 员工
我想合并 table send_to_employees
和 onprocess
这两个。之后我想将结果与 employees
table.
我已经在原始 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.
的查询生成器编写此查询试试这个代码片段。我认为它应该工作。我正在使用查询生成器
//从table
获取所有记录 $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();
你要找的是这样的:
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()
,因为它会包装一个集合并因此失败。