PHP   发布时间:2022-04-04  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了使用JOIN未能成功通过PHP查询MySQL数据库大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

这是我的数据库架构:

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构建测验Web应用程序,但遇到了麻烦.目前,我正在尝试(但不走运)此查询,并且我知道问题出在哪里,我只是不知道如何解决.因此,为什么我在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来获取测验标题的同时,如何维护原子数据库架构?任何帮助将非常感激!

解决方法:

我相信问题是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");

大佬总结

以上是大佬教程为你收集整理的使用JOIN未能成功通过PHP查询MySQL数据库全部内容,希望文章能够帮你解决使用JOIN未能成功通过PHP查询MySQL数据库所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: