我正在尝试将语言环境数据传递给eloquent查询,但它无法获取它。 $locale
值取自URI。
class MyController extends Controller
{
public function index($locale = 'en')
{
$news = News::join('categories', 'categories.id', '=', 'news.catid')
->select('news.*', 'categories.category')
->where([['news.published', '1'], ['news.deleted', '0']])
->where(function ($query) {
$query->where('news.language', $locale) //$locale is not recognized naturally
->orWhere('news.language', 'all');
})
->orderBy('news.published_at', 'desc')
->take(4)
->get();
.
.
.
}
}
如何将$locale
值传递给子查询?
答案 0 :(得分:7)
您可以使用use
构造在变量周围创建闭包:
->where(function ($query) use($locale) {
$query->where('news.language', $locale)
->orWhere('news.language', 'all');
})
参见manual中的示例#3,“从父作用域继承变量”。