한 응답으로 다중 응답 데이터 반환
제공된 코드는 데이터베이스에서 여러 레코드를 검색하여 단일 응답으로 반환하려고 시도합니다. 그러나 fetchAll의 잘못된 사용으로 인해 결과를 병합하고 원하는 출력을 반환할 수 없습니다.
다음 코드는 수정된 솔루션을 제공합니다.
<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>
이 솔루션에서는:
결과적으로 이 코드는 데이터베이스에서 여러 행을 올바르게 가져와서 예상 출력과 일치하는 단일 응답으로 병합합니다.
위 내용은 PHP 및 PDO를 사용하여 하나의 응답으로 여러 응답 데이터를 반환하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!