【问题标题】:How to do this query with Laravel query builder如何使用 Laravel 查询生成器进行此查询
【发布时间】:2013-05-30 21:13:16
【问题描述】:

我正在尝试在 Laravel 中运行此查询,并希望使用查询生成器来执行此操作,因此我可以使用 paginate() 方法。但我似乎无法弄清楚如何让这个子查询运行。

原始查询是:

SELECT *
FROM (
SELECT *
FROM `order_history`
WHERE `customer_id` = '05033'
AND `part_number` LIKE 'M%'
ORDER BY `shippingdate` DESC) history
GROUP BY `part_number`

提前致谢!

【问题讨论】:

  • 你有没有尝试过?你想使用 Fluent 还是 Eloquent?
  • Eloquent 会更好,但 Fluent 也可以。稍后会发布一些试用版。

标签: php mysql laravel query-builder


【解决方案1】:
DB::table(order_history)->where(function($query)
                         {
                              $query->where('customer_id','=','05033')
                                    ->where('part_number','like','$m');
                         })
                         ->group('part_number')
                         ->paginate(10)
                         ->get();

应该是正确的

【讨论】:

  • 嗯,不是真的,在 paginate() 之后你不必做 get(),但除此之外,这会给我一个类似的查询:"select * from order_history where (customer_id = '05033' and part_number like 'M%') group by part_number" 这不是我需要的.我需要一个“FROM”子句的子查询
猜你喜欢
  • 2018-09-28
  • 1970-01-01
  • 2018-02-16
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2016-11-16
  • 2019-04-25
  • 2018-06-23
相关资源
最近更新 更多