如何为MySQL查询中的PHP中的数组密钥提取值的值



我在这里有一个SQL查询,可以从数据库中获取课程信息。变量courses是上一页通过会话保存的数组。如果我var_dump,这就是courses[]的样子。我选择了3门课程以放入会议。

array(3) 
{ 
[0]=> string(7) "CAD8405" 
[1]=> string(7) "CON8413" 
[2]=> string(7) "ENG8328" 
}

我的$selectedYear变量在2012年至2014年之间有所不同。以下是我有问题的地方。我的查询很好,无需检查。我无法让$courseCode显示为Course.CourseCode='$courseCode',因此我的查询不起作用。

这是我发现它令人困惑的地方。$courses数组返回一个普通数组。但是,当我做$courses[0] = $courseCode;时,var_dump($courseCode) = null 这就是使我相信我需要的数据是我的课程ID是$courses[]数组的键。当尝试访问$courses[1]时,代码认为它是一个多维数组,将密钥作为第一个数据。但是我可能是错的 有更好的方法来提取我的数组的钥匙吗?

for($i = 0; $i < count($courses); $i++)
{
    //$courses[$i] = $courseCode;
    $courseCode = $courses[$i];
    $comfirmationString = "SELECT Course.CourseCode, Course.Title, Course.WeeklyHours, Semester.SemesterCode FROM Course, Semester, CourseOffer
    WHERE Semester.YearNum='$selectedYear' AND Course.CourseCode='$courseCode'
    AND Course.CourseCode=CourseOffer.CourseCode AND Semester.SemesterCode=CourseOffer.SemesterCode";
if($comfirmationResult = mysqli_query($link, $comfirmationString))
    {
        while($row = mysqli_fetch_assoc($comfirmationResult))
        {
            echo "<tr><td>$row[CourseCode]</td><td>$row[Title]</td><td>$row[WeeklyHours]</td><td>$row[SemesterCode]</td></tr>";
        }
    }
    else
    {
        echo "<p>Query error: " + mysqli_error($link) + "</p>";
    }
}

以下是显示我如何保存$courses[]变量的代码:我得到查询的结果,如果检查了复选框,则将此课程插入courses[]数组中。

if($Result2013 = mysqli_query($link, $string2013))
    {
        echo "<form action='CourseSelection.php' method='get'>
        <table><tr><th>Code</th><th>Course Title</th><th>Hours</th><th>Term</th><th>Select</th></tr>";
        while($row2013 = mysqli_fetch_assoc($Result2013))
        {
            echo "<tr><td>$row2013[CourseCode]</td><td>$row2013[Title]</td><td>$row2013[WeeklyHours]</td>
            <td>$row2013[Term]</td><td><input type='checkbox' name='courses[]' value=$row2013[CourseCode]></td></tr>";
        }
        echo "</table>";
    }

您可能需要修改查询以将复合值与易于读取值相关联,例如:

$comfirmationString = "SELECT Course.CourseCode as courseCode, Course.Title as courseTitle, Course.WeeklyHours as courseWeeklyHours, Semester.SemesterCode as semesterCode FROM Course, Semester, CourseOffer
WHERE Semester.YearNum='$selectedYear' AND Course.CourseCode='$courseCode'
AND Course.CourseCode=CourseOffer.CourseCode AND Semester.SemesterCode=CourseOffer.SemesterCode";

您还需要将变量包裹在括号中,例如:

echo "<tr><td>{$row['CourseCode']}</td><td>{$row['courseTitle']}</td><td>{$row['courseWeeklyHours']}</td><td>$row[SemesterCode]</td></tr>";

等等。

相关内容

  • 没有找到相关文章

最新更新