我做了一个select语句,它有多个输出。
但是当我尝试返回它时,只返回最后一个。这是我的代码。
$stmt->execute();
$row = $stmt->fetchAll();
$result = [];
foreach ($row as $fullName => $type) {
$result['fullName'] = $type['name'] . ' ' .$type['lastname'];
$result['class_type'] = $type['typ'];
var_dump($result['fullName']);
}
return $result;我的var-dump返回4个结果,但我的return只返回var转储的最后一个结果。
我在这里做错了什么?
发布于 2019-06-07 02:23:03
如果正确构造查询,则不需要使用foreach:
SELECT CONCAT(name, " ", lastname) AS fullName, typ AS class_type FROM table_name然后只需获取所有行并返回它们:
$stmt->execute();
return $stmt->fetchAll(PDO::FETCH_ASSOC);发布于 2019-06-07 02:19:14
您正在重写代码中的值。您需要将每个结果推送到数组中。请参阅下面的代码以供参考。
$stmt->execute();
$row = $stmt->fetchAll();
$result = [ ];
foreach ($row as $fullName => $type) {
$result[] = [
'fullName' => $type['name'] . ' ' .$type['lastname'],
'class_type' => $type['typ'] ];
// var_dump($result['fullName']);
}
return $result;https://stackoverflow.com/questions/56482985
复制相似问题