Laravel:如何仅在字段值不为NULL时应用where条件

时间:2015-08-31 13:29:10

标签: laravel where-clause

尝试在laravel中编写查询:

 return DB::table('course_modules')->select('module_id', 'publish_from', 'publish_to')
                    ->where('course_id', $course_id)
                    ->where('is_deleted', '0')
                 ->orwhere('publish_from', '>=', date('Y-m-d H:i:s'))
                    ->orwhere('publish_to', '<=', date('Y-m-d H:i:s'))
                    ->orwhere(function($query) {
                                $query->where('publish_from', '>=', date('Y-m-d H:i:s'))
                                ->where('publish_to', '<=', date('Y-m-d H:i:s'));
                            })
                    ->where('hide_module', 1)
                    ->get();

我想只在那些字段不为NULL时才在publish_to和publish_from上应用where子句。

我想这样做:

 if(publish_from!=NULL){   ->orwhere('publish_from', '>=', date('Y-m-d H:i:s'))}   

和同样的方式:

 if(publish_to!=NULL){   ->orwhere('publish_to', '>=', date('Y-m-d H:i:s'))}

没有得到确切的方法。帮助...

1 个答案:

答案 0 :(得分:2)

你必须重新考虑一下你的逻辑,因为SQL语句对于条件语句不是很好......所以你真正想要的是publish_frompublish_to要么是NULL或者在某个范围内。

这应该实现:

return DB::table('course_modules')->select('module_id', 'publish_from', 'publish_to')
    ->where('course_id', $course_id)
    ->where('is_deleted', '0')
    ->where('hide_module', 1)
    ->where(function($q){
        $q->where(function($q){
            $q->whereNull('publish_from')
              ->whereNull('publish_to');
        })->orWhere(function($q){
            $q->where('publish_from', '>=', date('Y-m-d H:i:s'))
              ->where('publish_to', '<=', date('Y-m-d H:i:s'));
        });
    })
    ->get();

请注意,这里不一定需要两级嵌套闭包,但它更容易阅读并避免错误。

此外,您可以为date('Y-m-d H:i:s')切换Carbon::now(),如果您问我,这会更好一些。