Mô hình của bạn sẽ trông giống như thế này trong Laravel 4. L3 có thể khá giống nhưng tôi có rất ít kinh nghiệm về điều đó.
<?php
class Restaurant extends Illuminate\Database\Eloquent\Model
{
protected $table = 'restaurants';
public function getSomeShit()
{
return $this
->select('*')
->select(DB::raw('( 3959 * acos( cos( radians(21.420639) ) * cos( radians( lat ) ) * cos( radians( lon ) - radians(-157.805745) ) + sin( radians(21.420639) ) * sin( radians( lat ) ) ) ) AS distance'))
->groupBy('id')
->having('distance', '<', 25)
->having('ratingsTotal', '>', 0)
->orderBy('distance')
->limit(5);
}
}
Hãy nhớ rằng bạn không bao giờ đặt logic cơ sở dữ liệu phức tạp (hoặc bất kỳ) nào trong bộ điều khiển, luôn đứng sau một chế độ xem.