为什么不在laravel 5.3工作?

时间:2017-04-26 09:22:44

标签: laravel laravel-5.3 laravel-eloquent

我的laravel雄辩是这样的:

public function search(Request $request)
{
    $search = '';
    $searchdate = '2017-04-27';

    $reports = Report::whereHas('user', function($query) use ($search) 
    {
        $query->where(function ($q) use($search)
        {
            $q->where('name' ,'LIKE' ,'%'.$search.'%');
        });
    })->orWhereHas('store', function($query) use ($search){
        $query->where(function ($q) use($search)
        {
            $q->where('name', 'LIKE', '%'.$search.'%');
        });
    })->orWhereHas('category', function($query) use ($search)
    {
        $query->where(function ($q) use($search)
        {
            $q->where('name', 'LIKE' , '%'.$search.'%');
        });
    })->whereDate('created_at','=',$searchdate)->paginate(10);
}

执行时,结果与过滤器$searchdate

不匹配

我该如何解决?

更新

我调试查询,结果如下:

SELECT * 
FROM `reports` WHERE (
    EXISTS (SELECT * FROM `users` WHERE `reports`.`user_id` = `users`.`id` AND (`name` LIKE '%%') AND `users`.`deleted_at` IS NULL) 
    OR EXISTS (SELECT * FROM `stores` WHERE `reports`.`reportable_id` = `stores`.`id` AND (`name` LIKE '%%') AND `stores`.`deleted_at` IS NULL) 
    OR EXISTS (SELECT * FROM `categories` WHERE `reports`.`category_id` = `categories`.`id` AND (`name` LIKE '%%') AND `categories`.`deleted_at` IS NULL) 
    AND DATE(`created_at`) = '2017-04-27'
) 
AND `reports`.`deleted_at` IS NULL

似乎它不起作用。因为

  

AND DATE(created_at)=' 2017-04-27'

在圆括号内

所以,它必须改变如下:

SELECT * 
FROM `reports` WHERE (
    EXISTS (SELECT * FROM `users` WHERE `reports`.`user_id` = `users`.`id` AND (`name` LIKE '%%') AND `users`.`deleted_at` IS NULL) 
    OR EXISTS (SELECT * FROM `stores` WHERE `reports`.`reportable_id` = `stores`.`id` AND (`name` LIKE '%%') AND `stores`.`deleted_at` IS NULL) 
    OR EXISTS (SELECT * FROM `categories` WHERE `reports`.`category_id` = `categories`.`id` AND (`name` LIKE '%%') AND `categories`.`deleted_at` IS NULL) 
) 
AND DATE(`created_at`) = '2017-04-27'
AND `reports`.`deleted_at` IS NULL

我的问题是如何改变雄辩的laravel?

1 个答案:

答案 0 :(得分:2)

将查询更改为

$reports = Report::where(function($q) use ($search){
   $q->whereHas('user', function($query) use ($search) {
        $query->where(function ($q) use($search){
            $q->where('name' ,'LIKE' ,'%'.$search.'%');
        });
     })->orWhereHas('store', function($query) use ($search){
        $query->where(function ($q) use($search){
            $q->where('name', 'LIKE', '%'.$search.'%');
        });
     })->orWhereHas('category', function($query) use ($search){
        $query->where(function ($q) use($search){
             $q->where('name', 'LIKE' , '%'.$search.'%');
     });
  });
})->whereDate('created_at','=',$searchdate)->paginate(10);

希望有所帮助