带有预制字符串的 Laravel 动态查询


Laravel dynamic queries with premade string

如何在拉拉维尔中插入字符串作为查询?我必须处理"书籍格式"(例如"pdf","epub","物理","")的动态值,并且此格式用逗号分隔。这是我的代码:

$formats_sql = '';
$format_filter_count = 0;
$format_filter = explode(',', $format_filter);
foreach ($format_filter as $format_filter_tmp) {
    if ($format_filter_count == 0) {
        $formats_sql .= "where('format', '=', '{$format_filter_tmp}')";
    } else {
        $formats_sql .= "->orWhere('format', '=', '{$format_filter_tmp}')";
    }
    $format_filter_count += 1;
}
if ($price_filter == 'paid') {
    $books = Book::where('book_id', '=', $category_book->book_id)->$formats_sql->where('sell_price', '>', '0')->where('status', '=', '1')->get();
}

但是制造了这个问题:

Undefined property: Illuminate'Database'Eloquent'Builder::$where('format', '=', 'pdf')->orWhere('format', '=', 'epub') 

你把这个问题复杂化了。您应该在需要搜索值数组的地方使用whereIn

上面的整个代码可以压缩为:

if ($price_filter == 'paid') {
    $formats = explode(',', $format_filter);
    Book::where('book_id', $category_book->book_id)->whereIn('format', $formats)->where('sell_price', '>', '0')->where('status', '1')->get();
}