I have the following function:
public function searchJoin(){
$first = $this->getModel()
->join('tarea_x_usuario', 'tarea_x_usuario.idTarea', '=', 'tarea.id')
->rightJoin('usuario', 'usuario.id', '=', 'tarea_x_usuario.idUsuario')
->join('role_x_usuario', 'role_x_usuario.idUsuario', '=', 'usuario.id')
->join('role', 'role.id', '=', 'role_x_usuario.idRole')
->get();
return $this->getModel()
->join('tarea_x_usuario', 'tarea_x_usuario.idTarea', '=', 'tarea.id')
->rightJoin('usuario', 'usuario.id', '=', 'tarea_x_usuario.idUsuario')
->join('role_x_usuario', 'role_x_usuario.idUsuario', '=', 'usuario.id')
->join('role', 'role.id', '=', 'role_x_usuario.idRole')
->where('role.role','=','ADMINISTRADORR')
->union($first)
->get();
}
I get the following error:
BadMethodCallException in Macroable.php line 74: Method getBindings does not exist.
Also try to make the following query:
public function searchJoin () {
$first = $this->getModel()
->join('tarea_x_usuario', 'tarea_x_usuario.idTarea', '=', 'tarea.id')
->rightJoin('usuario', 'usuario.id', '=', 'tarea_x_usuario.idUsuario')
->join('role_x_usuario', 'role_x_usuario.idUsuario', '=', 'usuario.id')
->join('role', 'role.id', '=', 'role_x_usuario.idRole')
->where('role.role', '=', 'ADMINISTRADORR')
->get();
$two = $this->getModel()
->join('tarea_x_usuario', 'tarea_x_usuario.idTarea', '=', 'tarea.id')
->rightJoin('usuario', 'usuario.id', '=', 'tarea_x_usuario.idUsuario')
->join('role_x_usuario', 'role_x_usuario.idUsuario', '=', 'usuario.id')
->join('role', 'role.id', '=', 'role_x_usuario.idRole')
->get();
dd($first->union($two)->get());
}
The two queries work, it throws error in the union.
The sequence of errors are: