Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/ant/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 除非我选择主键,否则Laravel急切加载不起作用_Php_Laravel_Eloquent - Fatal编程技术网

Php 除非我选择主键,否则Laravel急切加载不起作用

Php 除非我选择主键,否则Laravel急切加载不起作用,php,laravel,eloquent,Php,Laravel,Eloquent,我有两张桌子:学生桌和俱乐部桌,它们有着多对多的关系 作为ajax调用的一部分,我想返回所有学生及其俱乐部,但我想排除学生主键,因为这会提供有关系统中学生人数的意外信息 $students = Student::all() ->with('clubs') ->select('students.name', 'students.grade', 'students.birthday') ->get(); 这将返回俱乐部的空数组。 如果我将第三行更改为

我有两张桌子:学生桌和俱乐部桌,它们有着多对多的关系

作为ajax调用的一部分,我想返回所有学生及其俱乐部,但我想排除学生主键,因为这会提供有关系统中学生人数的意外信息

$students = Student::all()
     ->with('clubs')
     ->select('students.name', 'students.grade', 'students.birthday')
     ->get();
这将返回俱乐部的空数组。 如果我将第三行更改为包含id,它将完美地工作

$students = Student::all()
     ->with('clubs')
     ->select('students.id', 'students.name', 'students.grade', 'students.birthday')
     ->get();
排除主键的最佳方法是什么?我应该在查询之后通过循环集合来删除它吗?

我认为您可以使用“从集合中忘记”来删除它

https://laravel.com/docs/5.8/collectionsmethod-forget

我想你可以用收藏中的遗忘


https://laravel.com/docs/5.8/collectionsmethod-forget

我不知道这个存在!非常感谢。我不知道这个存在!非常感谢。你有像club_student这样的透视表吗?@Viney是的,我有。试试这个学生::使用“clubs”->选择“students.name”、“students.grade”、“students.Birth”->获取;不确定发生了什么,但这给了我一个内部服务器错误500。@Viney发现我遗漏了get语句。请求现在已完成,但clubs数组仍然为空。您有club_student这样的透视表吗?@Viney是的,我有。请尝试此学生::使用“clubs”->选择“students.name”、“students.grade”、“students.Birth”->get;不确定发生了什么,但这给了我一个内部服务器错误500。@Viney发现我遗漏了get语句。请求现在完成,但clubs数组仍然为空。