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

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

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

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

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

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

阅读 2.8k
4 个回答

因为 find 获取到的是单条数据;是一维数组;
而 get 获取到的是多条数据的二维数组;
如果想用 where 还想获取一条的一维数组需要用 first;
写成下面这种形式就可以喽;

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

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

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

实际项目中很少用find 方法吧,find(1) 默认的是 主键id搜索,都是一对一的,所以你一对多或者多对多,find()不合适
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题