Muh*_*zim 4 mysql laravel eloquent
我有一个值为 1,2 的数组。例如。
$arr = []
foreach($permission as $perm)
{
$arr[] = $perm->permission
}
dd(implode(',',$arr));
result shows 1,2
Run Code Online (Sandbox Code Playgroud)
但是当我在查询中使用 $arr 时,它无法正常工作。我在以下查询中使用它
$response = implode(',',$arr);
$role = Role::whereNotIn('id',[$response])->get();
//means select * from role where id not in (1,2);
Run Code Online (Sandbox Code Playgroud)
但它的工作原理如下
select * from role where id not in (1);
Run Code Online (Sandbox Code Playgroud)
你们能帮我解决这个问题吗
您传递的字符串是“1,2”。您必须将数组而不是字符串传递给该whereNotIn()方法:
$role = Role::whereNotIn('id', $arr)->get();
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
4461 次 |
| 最近记录: |