Aye*_*une 5 laravel laravel-query-builder
根据 Laravel 文档,可以通过将 Closure 作为第一个参数传递给 orWhere 方法来对“or”条件进行分组:
$users = DB::table('users')
->where('votes', '>', 100)
->orWhere(function($query) {
$query->where('name', 'Abigail')
->where('votes', '>', 50);
})
->get();
Run Code Online (Sandbox Code Playgroud)
我想要的是在查询中使用一个变量,它看起来像:
$q = $request->get('query');
$users = DB::table('users')
->where('votes', '>', 100)
->orWhere(function($query) {
$query->where('name', $q)
->where('votes', '>', 50);
})
->get();
Run Code Online (Sandbox Code Playgroud)
我尝试将其作为第二个参数传递,例如:
$q = $request->get('query');
$users = DB::table('users')
->where('votes', '>', 100)
->orWhere($q, function($query, $q) {
$query->where('name', $q)
->where('votes', '>', 50);
})
->get();
Run Code Online (Sandbox Code Playgroud)
但它不起作用,有什么帮助吗?
你需要使用use()函数将数据传递到更近的引用链接在 PHP 中,什么是闭包以及为什么它使用“use”标识符?
$q = $request->get('query');
$users = DB::table('users')
->where('votes', '>', 100)
->orWhere(function ($query) use($q) { // use function to pass data inside
$query->where('name', $q)
->where('votes', '>', 50);
})
->get();
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
6168 次 |
| 最近记录: |