请教一个laravel模型关联查询的问题

关联查询的时候按照文档所说

Supplier::find(1)->member()->get()

这个样子可以查出数据,我如果把find换成where就会报错

$supplier->where('status',1)->get()->member()

请问这个是什么原因,如果这么写的话该怎么修改

隔江千里
浏览 398回答 4
4回答

慕妹3242003

因为 find 获取到的是单条数据;是一维数组;而 get 获取到的是多条数据的二维数组;如果想用 where 还想获取一条的一维数组需要用 first;写成下面这种形式就可以喽; $supplier->where('status', 1)->first()->member()->get();

翻翻过去那场雪

楼上说的很清楚,按照你说的 “如果我想获取get到的所有的应该怎么写”,没有这个使用场景,因为你不能保证每条数据的member是一样的,所以从设计上来说就不合理。

绝地无双

这样试试$supplier->where('status',1)->member()->get()

心有法竹

实际项目中很少用find 方法吧,find(1) 默认的是 主键id搜索,都是一对一的,所以你一对多或者多对多,find()不合适
打开App,查看更多内容
随时随地看视频慕课网APP