Mehrere Antwortdaten in einer Antwort zurückgeben
Der bereitgestellte Code versucht, mehrere Datensätze aus einer Datenbank abzurufen und sie in einer einzigen Antwort zurückzugeben. Aufgrund der falschen Verwendung von fetchAll ist es jedoch nicht möglich, die Ergebnisse zusammenzuführen und die gewünschte Ausgabe zurückzugeben.
Der folgende Code bietet eine korrigierte Lösung:
<code class="php">try { $dbAdapter = new DbAdapter(); $connection = $dbAdapter->connect(); // User IDs to be fetched. $userIds = [1, 2]; // The sql statement - it will be prepared. $sql = 'SELECT users.id AS userid, users.name AS username, subjects.id AS subject_id, subjects.name AS subject_name, subjects.points AS active_points, IFNULL(SUM(subjects.points), 0) AS total_points, ( SELECT IFNULL(SUM(points), 0) FROM subjects WHERE userid = users.id AND semester = 1 ) AS semester_1_points, ( SELECT IFNULL(SUM(points), 0) FROM subjects WHERE userid = users.id AND semester = 2 ) AS semester_2_points, ( SELECT IFNULL(SUM(points), 0) FROM subjects WHERE userid = users.id AND semester = 3 ) AS semester_3_points FROM tbsubjects AS subjects LEFT JOIN tbusers AS users ON users.id = subjects.userid WHERE subjects.userid IN (:userIds) GROUP BY subjects.userid ORDER BY subjects.time DESC'; // The input parameters list for the prepared sql statement. $bindings = array( ':userIds' => $userIds, ); // Prepare and validate the sql statement. $statement = $connection->prepare($sql); if (!$statement) { throw new UnexpectedValueException('The sql statement could not be prepared!'); } // Bind the input parameters to the prepared statement. foreach ($bindings as $key => $value) { $bound = $statement->bindValue( getInputParameterName($key), $value, getInputParameterDataType($value) ); if (!$bound) { throw new UnexpectedValueException('An input parameter can not be bound!'); } } // Execute the prepared statement. $executed = $statement->execute(); if (!$executed) { throw new UnexpectedValueException('The prepared statement could not be executed!'); } // Fetch users list - array of objects. $users = $statement->fetchAll(PDO::FETCH_OBJ); if ($users === FALSE) { throw new UnexpectedValueException('Fetching users list failed!'); } // Close connection. $connection = NULL; // Handle results. if (empty($users)) { $response->getBody()->write( '{ "error": { "message":"Invalid" } }' ); } else { $response->getBody()->write(json_encode($users)); } } catch (PDOException $exc) { echo $exc->getMessage(); // $logger->log($exc); exit(); } catch (Exception $exc) { echo $exc->getMessage(); // $logger->log($exc); exit(); }</code>
In dieser Lösung:
Als Ergebnis ruft dieser Code korrekt mehrere Zeilen aus der Datenbank ab und führt sie in einer einzigen Antwort zusammen, die der erwarteten Ausgabe entspricht.
Das obige ist der detaillierte Inhalt vonWie kann ich mit PHP und PDO mehrere Antwortdaten in einer Antwort zurückgeben?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!