我使用下面的代码从Laravel 5的数据库中提取一些结果。

BookingDates::where('email', Input::get('email'))->orWhere('name', 'like', Input::get('name'))->get()

然而,orWhereLike似乎没有匹配任何结果。这段代码在MySQL语句方面产生了什么?

我正在努力实现以下内容:

select * from booking_dates where email='my@email.com' or name like '%John%'

当前回答

我有这个仪器,希望能帮到别人。 https://laravel.com/docs/master/eloquent#local-scopes

public function scopeWhereLike($query, $column, $value)
{
    return $query->where($column, 'like', '%'.$value.'%');
}

public function scopeOrWhereLike($query, $column, $value)
{
    return $query->orWhere($column, 'like', '%'.$value.'%');
}

用法:

$result = BookingDates::whereLike('email', $email)->orWhereLike('name', $name)->get();

其他回答

我有这个仪器,希望能帮到别人。 https://laravel.com/docs/master/eloquent#local-scopes

public function scopeWhereLike($query, $column, $value)
{
    return $query->where($column, 'like', '%'.$value.'%');
}

public function scopeOrWhereLike($query, $column, $value)
{
    return $query->orWhere($column, 'like', '%'.$value.'%');
}

用法:

$result = BookingDates::whereLike('email', $email)->orWhereLike('name', $name)->get();

如果您想要查看在数据库中运行了什么,请使用dd(DB::getQueryLog())来查看运行了什么查询。

试试这个

BookingDates::where('email', Input::get('email'))
    ->orWhere('name', 'like', '%' . Input::get('name') . '%')->get();

如果您正在使用Postgres,则可以使用关键字ILIKE而不是LIKE来根据活动地区使匹配不区分大小写。这不是SQL标准,而是一个PostgreSQL扩展。

这对我很管用。

User::where('name, 'ILIKE', $search)->get();

postgres文档

下面提到的查询对我有用,也许对其他人会有帮助。

 $platform = DB::table('idgbPlatforms')->where('name', 'LIKE',"%{$requestedplatform}%")->first();

如果你想在控制器上使用它,你可以这样做:

$generatequery = 'select * from where is_active = 1 and blog_name like '%'.$blogs。'%'命令由updated_at desc, id desc';

$ bloglists = DB::select($generatequery);