Объединение Laravel и соединение в запросе

у меня 3 стола

  1. отправить_сотрудникам
  2. в процессе
  3. сотрудники

Я хочу сделать объединение двух таблиц send_to_employees и onprocess. После этого я хочу соединить результат с таблицей 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.


person Saddam Hussain    schedule 01.06.2019    source источник
comment
Если вы можете поделиться описанием таблицы вместе с ожидаемым форматом результата.   -  person Naranz    schedule 01.06.2019


Ответы (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() в подзапросе, так как это приведет к обертыванию коллекции и, следовательно, к ошибке.

person Namoshek    schedule 01.06.2019
comment
Вы действительно круты, сэр. Большое спасибо. Очень понравилось. - person Saddam Hussain; 22.06.2019

Попробуйте этот фрагмент кода. Я думаю, это должно сработать. Я использую построитель запросов

//получение всех записей из таблицы

 $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();
person Julius Fasema    schedule 01.06.2019
comment
вы также можете попробовать только присоединиться вместо leftjoin - person Julius Fasema; 01.06.2019