首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Laravel查询大楼中使用Array in '->where()‘

在Laravel查询大楼中使用Array in '->where()‘
EN

Stack Overflow用户
提问于 2015-12-16 12:17:48
回答 2查看 259关注 0票数 3

我正在尝试获取列的所有值,然后在另一个查询中使用它。我使用lists并将值作为数组获取,但是,在其他查询中无法找到检查该变量(包含每个id的数组)的方法

代码语言:javascript
复制
$subscribes = Subscribe::where('from_id', $currentUser)->lists('id')

// dd($subscribes), logs values as array.


$videos = Photo::where('id', $subscribes)->get();

这不起作用,因为$subscribes是一个数组。

我应该使用for循环并为每个id发送另一个查询吗?还是有一种实用的方法让我错过了?使用它的正确方法是什么?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-12-16 12:21:51

使用whereIn方法:

代码语言:javascript
复制
$videos = Photo::whereIn('id', $subscribes)->get();

http://laravel.com/docs/5.1/queries (向下滚动/搜索'whereIn')

票数 3
EN

Stack Overflow用户

发布于 2015-12-16 12:25:04

应用whereIn方法

代码语言:javascript
复制
if(is_array($subscribes) && count($subscribes) > 0){
    $videos = Photo::whereIn('id', $subscribes)->get();
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34311842

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档