如何检查字段是否为雄辩不为空?

我试着模型::(‘sent_at’,‘不是’,DB::生(“空”))- >…但它给出了IS NOT作为一个绑定,而不是一个比较。

这是DB::getQueryLog()所说的:

  'query' => string 'select * from my_table where sent_at = ? and profile_id in (?, ?) order by created_at desc' (length=101)
  'bindings' => 
    array (size=3)
      0 => string 'IS NOT' (length=6)
      1 => int 1
      2 => int 4

当前回答

Eloquent对此有一个方法(Laravel 4.*/5.*);

Model::whereNotNull('sent_at')

Laravel 3:

Model::where_not_null('sent_at')

其他回答

如果像我这样的人想用Laravel 5.2.23中的查询生成器来做,可以像->这样做

 $searchResultQuery = Users::query(); 
 $searchResultQuery->where('status_message', '<>', '', 'and'); // is not null
 $searchResultQuery->where('is_deleted', 'IS NULL', null, 'and'); // is null 

或与scope in model:

public function scopeNotNullOnly($query){

    return $query->where('status_message', '<>', '');
}

如果你想搜索已删除的记录(软删除记录),不要使用雄辩模型查询。

请使用Db::table查询。例如:

而不是:

$stu = Student::where('rollNum', '=', $rollNum . '-' . $nursery)->first();

Use:

$stu = DB::table('students')->where('rollNum', '=', $newRollNo)->first();

检查“非空”

Model::whereNotNull('column1');

检查“零”

Model::whereNull('column1');

另一个解决方案是使用whereRaw()

Model::whereRaw("column1 IS NOT NULL");
Model::whereRaw("column1 IS NULL");

在laravel 5.4中,这段代码Model::whereNotNull('column')不起作用,你需要像这样添加get() Model::whereNotNull('column')->get();这个很适合我。

如果你想使用DB facade:

DB: table(“table_name”)- > whereNotNull(“sent_at”)- > get ();