Laravel 中的嵌套数组
Nested arrays in Laravel
我正在与 Laravel 合作,并试图通过查询解决困难的情况。
任何人都知道,为什么结果我得到这个?试图将第一个查询的结果传递给第二个。
这是第一个查询。一切看起来都不错
$teach_id = auth()->id();
$cur_subj = DB::table('subject')->select('sId')->where('id', '=', $teach_id)->get();
array:3 [▼
0 => {#398 ▼
+"sId": "1"
}
1 => {#399 ▼
+"sId": "2"
}
2 => {#400 ▼
+"sId": "3"
}
]
正在尝试将此数组传递到此处
foreach ($cur_subj as $key => $value){
$studs[] = DB::table('stud')
->join('subject', 'stud.sId', '=', 'subject.sId')
->join('users', 'users.id', '=', 'stud.id')
->select('users.name', 'subject.sName')
->where('stud.sId', $value->sId)
->get();
}
结果我看到了
array:3 [▼
0 => array:2 [▼
0 => {#403 ▼
+"name": "Багрянцев К. Н."
+"sName": "История"
}
1 => {#404 ▼
+"name": "Суворова Е. А."
+"sName": "История"
}
]
1 => array:1 [▼
0 => {#405 ▼
+"name": "Багрянцев К. Н."
+"sName": "Алгебра"
}
]
2 => []
]
不明白,为什么第二次查询的结果插入到第一次查询的数组中?如何解决这个问题?
因为get
returns集合,所以$studs
是集合数组
尝试
$studs = collect([]);
foreach ($cur_subj as $key => $value)
{
$c = DB::table('stud')
->join('subject', 'stud.sId', '=', 'subject.sId')
->join('users', 'users.id', '=', 'stud.id')
->select('users.name', 'subject.sName')
->where('stud.sId', $value->sId)
->get();
$studs = $studs->merge($c);
}
我正在与 Laravel 合作,并试图通过查询解决困难的情况。
任何人都知道,为什么结果我得到这个?试图将第一个查询的结果传递给第二个。
这是第一个查询。一切看起来都不错
$teach_id = auth()->id();
$cur_subj = DB::table('subject')->select('sId')->where('id', '=', $teach_id)->get();
array:3 [▼
0 => {#398 ▼
+"sId": "1"
}
1 => {#399 ▼
+"sId": "2"
}
2 => {#400 ▼
+"sId": "3"
}
]
正在尝试将此数组传递到此处
foreach ($cur_subj as $key => $value){
$studs[] = DB::table('stud')
->join('subject', 'stud.sId', '=', 'subject.sId')
->join('users', 'users.id', '=', 'stud.id')
->select('users.name', 'subject.sName')
->where('stud.sId', $value->sId)
->get();
}
结果我看到了
array:3 [▼
0 => array:2 [▼
0 => {#403 ▼
+"name": "Багрянцев К. Н."
+"sName": "История"
}
1 => {#404 ▼
+"name": "Суворова Е. А."
+"sName": "История"
}
]
1 => array:1 [▼
0 => {#405 ▼
+"name": "Багрянцев К. Н."
+"sName": "Алгебра"
}
]
2 => []
]
不明白,为什么第二次查询的结果插入到第一次查询的数组中?如何解决这个问题?
因为get
returns集合,所以$studs
是集合数组
尝试
$studs = collect([]);
foreach ($cur_subj as $key => $value)
{
$c = DB::table('stud')
->join('subject', 'stud.sId', '=', 'subject.sId')
->join('users', 'users.id', '=', 'stud.id')
->select('users.name', 'subject.sName')
->where('stud.sId', $value->sId)
->get();
$studs = $studs->merge($c);
}