在数组laravel上调用成员函数where()

时间:2018-01-19 06:41:27

标签: php mysql laravel join controller

我有两张桌子 tbl_law_master &的 tbl_law_sub_master 在这两个表上都有一个名为 assigned_to 的列,此列存储用户的ID。

我的任务是通过加入tbl_law_master的 law_id ,从tbl_law_sub_master获取特定用户ID sublaw

这是我的代码,

$law_id = $_GET['law_id'];

$sublaw = DB::table('tbl_law_sub_master')
            ->select('tbl_law_sub_master.*', 'tbl_law_master.lm_id', 'tbl_law_master.law_name', 'tbl_law_master.id as lawId')
            ->leftJoin('tbl_law_master', 'tbl_law_master.id', '=', 'tbl_law_sub_master.lm_id')
            ->where('tbl_law_sub_master.lm_id', $law_id)
            ->orderBy('type_of_event', 'asc')
            ->orderBy('section', 'asc')
            ->orderBy('rules', 'asc')
            ->orderBy('notification', 'asc')
            ->orderBy('circular', 'asc')->get();

if (!in_array(Auth::user()->role, [1, 7])) 
{
   $sublaw = $sublaw->where('tbl_law_master.assigned_to', Auth::user()->id);
}

它显示错误

  

调用成员函数where()on array

2 个答案:

答案 0 :(得分:2)

问题是您已经调用了get()的查询,然后再次调用where()

你应该像这样使用where子句函数

$sublaw = DB::table('tbl_law_sub_master')
        ->select('tbl_law_sub_master.*', 'tbl_law_master.lm_id', 'tbl_law_master.law_name', 'tbl_law_master.id as lawId')
        ->leftJoin('tbl_law_master', 'tbl_law_master.id', '=', 'tbl_law_sub_master.lm_id')
        ->where(function($query) use ($law_id) {
            $query->where('tbl_law_sub_master.lm_id', $law_id);
            if (!in_array(Auth::user()->role, [1, 7])) 
            {
                $query->where('tbl_law_master.assigned_to', Auth::user()->id);
            }
        })
        ->orderBy('type_of_event', 'asc')
        ->orderBy('section', 'asc')
        ->orderBy('rules', 'asc')
        ->orderBy('notification', 'asc')
        ->orderBy('circular', 'asc')->get();

答案 1 :(得分:0)

我认为你应该在最后一次where声明后调用get

$sublaw = DB::table('tbl_law_sub_master')
        ->select('tbl_law_sub_master.*', 'tbl_law_master.lm_id', 'tbl_law_master.law_name', 'tbl_law_master.id as lawId')
        ->leftJoin('tbl_law_master', 'tbl_law_master.id', '=', 'tbl_law_sub_master.lm_id')
        ->where('tbl_law_sub_master.lm_id', $law_id)
        ->orderBy('type_of_event', 'asc')
        ->orderBy('section', 'asc')
        ->orderBy('rules', 'asc')
        ->orderBy('notification', 'asc')
        ->orderBy('circular', 'asc');

if (!in_array(Auth::user()->role, [1, 7])) 
{
  $sublaw = $sublaw->where('tbl_law_master.assigned_to', Auth::user()->id)->get();
}