Maison >base de données >tutoriel mysql >Comment puis-je renvoyer plusieurs données de réponse en une seule réponse en utilisant PHP et PDO ?

Comment puis-je renvoyer plusieurs données de réponse en une seule réponse en utilisant PHP et PDO ?

DDD
DDDoriginal
2024-10-27 06:02:02283parcourir

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

Retourner les données à réponses multiples en une seule réponse

Le code fourni tente de récupérer plusieurs enregistrements d'une base de données et de les renvoyer en une seule réponse. Cependant, en raison d'une utilisation incorrecte de fetchAll, il n'est pas en mesure de fusionner les résultats et de renvoyer le résultat souhaité.

Le code suivant fournit une solution corrigée :

<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>

Dans cette solution :

  1. La méthode fetchAll est utilisée avec PDO::FETCH_OBJ pour récupérer un tableau d'objets, où chaque objet représente une ligne dans le jeu de résultats.
  2. Les getInputParameterName() et getInputParameterDataType personnalisés () sont utilisées pour lier correctement les paramètres d'entrée à l'instruction préparée.
  3. La fonction IFNULL est utilisée pour gérer les valeurs nulles dans les colonnes total_points, semester_1_points, semester_2_points et semester_3_points, garantissant qu'elles sont renvoyées à zéro si null.

En conséquence, ce code récupère correctement plusieurs lignes de la base de données et les fusionne en une seule réponse, qui correspond au résultat attendu.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn