Неудачное использование JOIN для запроса базы данных MySQL с помощью PHP - PullRequest
3 голосов
/ 06 октября 2011

Вот моя схема базы данных:

user
*user_id
*username
*password
*etc

quiz_response
*response_id
*user_id
*question_id
*response
*is_correct
*answer_time

question_choice
*choice_id
*question_id
*is_correct
*choice (VARCHAR)

question
*question_id
*quiz_id
*question (VARCHAR)

quiz
*quiz_id
*title (VARCHAR)

Я создаю веб-приложение для викторины, используя PHP, и у меня возникли проблемы. В настоящее время я пытаюсь - без удачи - этот запрос, и я знаю, где проблема, я просто не знаю, как ее решить. Следовательно, почему я здесь на S.O.

// Grab the response data from the database to generate the form
    $query = "SELECT qr.response_id AS r_id, qr.question_id, qr.response, q.question, quiz.title " . 
        "FROM quiz_response AS qr " . 
        "INNER JOIN question AS q USING (question_id) " . 
        "INNER JOIN quiz USING (quiz_id) " . 
        "WHERE qr.user_id = '" . $_SESSION['user_id'] . "'";
    $data = mysqli_query($dbc, $query) or die("MySQL error: " . mysqli_error($dbc) . "<hr>\nQuery: $query"); 

На данный момент я чувствую, что мое второе внутреннее соединение (викторина INNER JOIN USING (quiz_id)) является проблемой. Когда я не включаю эту строку и не удаляю quiz.title из запроса, он работает. Итак, мой вопрос как мне поддерживать атомарную схему базы данных, все еще выбирая заголовок викторины на основе quiz_id из таблицы 'question'? Любая помощь будет принята с благодарностью!

Ответы [ 2 ]

2 голосов
/ 06 октября 2011

Я считаю, что проблема в том, что quiz_id отсутствует в quiz_response. Я использую ключевое слово ON. Попробуйте:

// Grab the response data from the database to generate the form
$query = "SELECT qr.response_id AS r_id, qr.question_id, qr.response, q.question, 
          quiz.title " . 
         "FROM quiz_response AS qr " . 
         "INNER JOIN question AS q ON (q.question_id = qr.question_id) " . 
         "INNER JOIN quiz ON (quiz.quiz_id = q.quiz_id) " . 
         "WHERE qr.user_id = '" . $_SESSION['user_id'] . "'";
$data = mysqli_query($dbc, $query) or 
         die("MySQL error: " . mysqli_error($dbc) . "<hr>\nQuery: $query");
2 голосов
/ 06 октября 2011

Попробуйте с:

// Grab the response data from the database to generate the form
    $query = "SELECT qr.response_id AS r_id, qr.question_id, qr.response, q.question, quiz.title " . 
        "FROM quiz_response qr " . 
        "INNER JOIN question q USING (question_id) " . 
        "INNER JOIN quiz ON quiz.quiz_id = q.quiz_id " . 
        "WHERE qr.user_id = '" . $_SESSION['user_id'] . "'";
    $data = mysqli_query($dbc, $query) or die("MySQL error: " . mysqli_error($dbc) . "<hr>\nQuery: $query"); 
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...