2016-04-21 34 views
0

我需要在Laravel 5.1中创建一个选择查询,我不会通过常规SQL创建任何问题,我想知道是否可以帮助我将它写入Laravel。Laravel使用max和group进行查询

我创建了这个查询,获取所有拥有卡车,拖车和delivery_date等于特定日期(来自$ week_array)的用户。这是工作,但它缺少一些组件

$RS = $this->instance->user() 
     ->with(['driver.delivery' => function($query) use ($week_array) { 
      $query->where('delivery_date', [Carbon\Carbon::parse($week_array['date'])->toDateTimeString()]); 
      }]) 
     ->with(['driver.trailer', 'driver.truck', 'driver.trailer.trailerType'])->get(); 

我需要排除那些拥有它等于或大于上面的查询选择的交货日期更大MAX交货日期的驱动程序。这是我需要插入laravel的普通查询。

换句话说,我需要下面的查询(简体)转换为Laravel:

SELECT 
    * 
FROM 
    USERS 
     INNER JOIN 
    DRIVERS ON DRIVERS.user_id = USERS.id 
     INNER JOIN 
    DELIVERIES ON DELIVERIES.driver_id = DRIVERS.id 
WHERE 
    1 = 1 
     AND DELIVERIES.driver_id NOT IN (SELECT 
      driver_id 
     FROM 
      DELIVERIES 
     GROUP BY driver_id 
     HAVING MAX(delivery_date) >= '2016-05-10') 
+0

我很害怕我没有完全理解你的问题。你有选择MAX值的问题吗? – Jackowski

+0

我添加了一个简化的SQL,它正在工作,我试图将其转换为 – Andrew

回答

2

您正在寻找whereHas。尝试:

$date = Carbon\Carbon::parse($week_array['date'])->toDateTimeString(); 

$RS = $this->instance->user() 
    ->with(['driver.delivery' => function($query) use ($date) { 
     $query->where('delivery_date', [$date]); 
    }]) 
    ->with(['driver.trailer', 'driver.truck', 'driver.trailer.trailerType']) 
    ->whereHas('driver.delivery', function($query) use ($date) { 
     return $query->where('delivery_date', '>', $date); 
    }, '=', 0) 
    ->get(); 

也可以尝试验证查询期待权与->toSql()更换->get()和使用dd助手功能。

+0

好像你正在返回last_delivery日期,我需要确保driver_id不在最大列表中(deliveries.delivery_date)> = $ date – Andrew

+0

另外,得到这个错误:'未找到列:'字段列表'中的1054未知列'max(delivery_date)' – Andrew

+0

您是否可以复制并粘贴生成的SQL? – Scopey