Laravel 数据库 聚合+Join 查找语句。

聚合#

查询构造器也提供各式各样的聚合方法,如 count, max, min, avgsum

使用聚合方法#

$users = DB::table('users')->count();

$price = DB::table('orders')->max('price');

$price = DB::table('orders')->min('price');

$price = DB::table('orders')->avg('price');

$total = DB::table('users')->sum('votes');

但是对于复杂的情况(比如join 后的结果,其结果并不是个objet)。就不能直接使用上述的方法

解决方法:

db::raw('')

Raw Expressions#

有些时候您需要使用 raw expression 在查询语句里,这样的表达式会成为字串插入至查询中,因此要小心勿建立任何 SQL 注入的攻击点。要建立 raw expression,您可以使用 DB::raw 方法:

使用 Raw Expression#

$users = DB::table('users')
                     ->select(DB::raw('count(*) as user_count, status'))
                     ->where('status', '<>', 1)
                     ->groupBy('status')
                     ->get();

实际代码:

  1. /** 
  2. * sales deb export. 
  3. * @param 
  4. * @return .csv 
  5. */  
  6. private function _salesDEBExport()  
  7. {  
  8.     $objects = DB::table('orders')  
  9.                 ->join('order_products','orders.id','=','order_products.order_id')  
  10.                 ->join('products','order_products.product_id','=','products.id')  
  11.                 ->leftJoin('categories','products.category_id','=','categories.id')  
  12.   
  13.                 ->select(  
  14.                     'orders.external_id',  
  15.                     'orders.address_billing_name',  
  16.                     'categories.customs_code',  
  17.                     'orders.external_sale_date',  
  18.                     'orders.invoice_external_id',  
  19.                     'orders.payment_method',  
  20.                     'orders.address_shipping_country',  
  21.                     DB::raw('  
  22.                         SUM(order_products.amount_base) AS amount_base,  
  23.                         SUM(order_products.amount_tax) AS amount_tax,  
  24.                         SUM(order_products.amount_total) AS amount_total  
  25.                         ')  
  26.                     )  
  27.                 ->groupBy('orders.external_id','categories.customs_code')  
  28.                 ->whereIn('orders.object_state_id', array(2,3))  
  29.                 ->where('orders.created_at', 'like', Input::get('year') . '-' . Input::get('month') . '-%')  
  30.                 ->get();  
  31.   
  32.     if (empty($objects))  
  33.     {  
  34.         Notification::error("Aucune donnée disponible.");  
  35.         return Redirect::to(URL::previous());  
  36.     }else{            
  37.         $headers = array(  
  38.             'Content-Type'       => 'text/csv',  
  39.             'Content-Disposition' => 'attachment; filename="sales_deb_export_'.Input::get('month').'_'.Input::get('year').'.csv"',  
  40.             );  
  41.   
  42.         $output = rtrim(implode(',', array_keys((array) $objects[0]))) . "\n";  
  43.         foreach($objects as $object)  
  44.         {  
  45.             $output .= rtrim(implode(',', (array) $object)) . "\n";  
  46.         }  
  47.         return Response::make($output, 200, $headers);  
  48.   
  49.     } 
posted @ 2017-08-20 21:52  南风丨知我意  阅读(4721)  评论(0编辑  收藏  举报