ホームページ >データベース >mysql チュートリアル >PHP と PDO を使用して 1 つの応答で複数の応答データを返すにはどうすればよいですか?

PHP と PDO を使用して 1 つの応答で複数の応答データを返すにはどうすればよいですか?

DDD
DDDオリジナル
2024-10-27 06:02:02293ブラウズ

How can I return multiple response data in one response using PHP and PDO?

複数の応答データを 1 つの応答で返す

提供されたコードは、データベースから複数のレコードを取得し、それらを 1 つの応答で返そうとします。ただし、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>

この解決策では:

  1. fetchAll メソッドは PDO::FETCH_OBJ とともに使用され、オブジェクトの配列を取得します。各オブジェクトは結果セット内の行を表します。
  2. カスタムの getInputParameterName() および getInputParameterDataType () 関数は、入力パラメータをプリペアド ステートメントに正しくバインドするために使用されます。
  3. IFNULL 関数は、total_points、semester_1_points、semester_2_points、semester_3_points 列の null 値を処理するために使用され、次の場合にそれらの値がゼロとして返されるようにします。 null.

その結果、このコードはデータベースから複数の行を正しくフェッチし、それらを単一の応答にマージし、期待される出力と一致します。

以上がPHP と PDO を使用して 1 つの応答で複数の応答データを返すにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。