Подтвердить что ты не робот

Использовать переменную в heredoc в PHP (практика SQL)

Я новичок в PHP/SQL, и я пытаюсь использовать переменную в heredoc, поскольку мне нужно много текста. Я включил только первое предложение, так как этого достаточно, чтобы показать проблему).

Моя проблема в том, что в heredoc переменные (см. ниже: $data['game_name] и $data['game_owner']) не распознаются как переменная, а как обычный текст. Как я могу это решить?

<?php
try
{
    //i am connecting the the database base mysql 'test'
    $pdo_options[PDO::ATTR_ERRMODE] = PDO::ERRMODE_EXCEPTION;
    $bdd = new PDO('mysql:host=localhost;dbname=test', 'root', '', $pdo_options);
    //the i read the data in the databse 'video_dame'
    $response = $bdd->query('SELECT * FROM video_game');
    //pour qu'elle soit visible à l'écran, on affiche chaque entrée une à une
    while ($data= $response->fetch())
    {
    echo <<<'EX'
    <p>Game: $data['game_name]<br/>
    the owner of the game is $data['game_owner']
    </p>
    EX;
    }
    //i end the sql request
    $response->closeCursor();
}
catch (Exception $e)
{
    die('Error: '.$e->getMessage());
}
?>

Любая помощь будет высоко оценена.

4b9b3361

Ответ 1

Ваш Heredoc нуждается в небольшой модификации (потому что это фактически Nowdoc!):

    echo <<<EX
    <p>Game: {$data['game_name']}<br/>
    the owner of the game is {$data['game_owner']}
    </p>
EX;
  • Идентификаторы Heredoc (в отличие от nowdoc) не могут быть указаны. 'EX' должно стать EX.
  • Терминатор Heredoc не должен иметь предшествующих пробелов. Из документов:

    Очень важно отметить, что строка с закрывающим идентификатором не должна содержать других символов, кроме, возможно, точки с запятой (;).

    Вы запутываете Nowdoc с Heredoc.

  • Сложные типы данных в строках должны быть окружены {} для их анализа в качестве переменных. Например, $data['game_name] должен быть {$data['game_name]}.

Вы смешиваете heredoc и nowdoc здесь. Вы хотите использовать Heredoc, а не Nowdoc, потому что у вас есть переменные внутри вашей строки. Heredocs - это "расширенные" строки с двойными кавычками, тогда как nowdocs более схожи с одной кавычкой, поскольку переменные не обрабатываются в nowdoc-строках, а находятся в heredoc.

  • Подробнее о Heredoc here.
  • Подробнее о Nowdoc здесь.

Пожалуйста, внимательно ознакомьтесь с документацией.