Php 从数据库创建带循环的嵌套多维数组

Php 从数据库创建带循环的嵌套多维数组,php,arrays,multidimensional-array,Php,Arrays,Multidimensional Array,我已经为此工作了好几天,几乎把头发都拔了出来 我试图从FOREACH循环中输出JSON,这样我就可以用它来模板化每日的类调度。我已经走了大部分路,事情继续发生,或者出人意料 下面的代码生成了以下代码: { "DAY": "TUESDAY", "TIME": { "530": { "CLASSES": [ { "CLASS": { "INSTRUCTOR": "DANA",

我已经为此工作了好几天,几乎把头发都拔了出来

我试图从FOREACH循环中输出JSON,这样我就可以用它来模板化每日的类调度。我已经走了大部分路,事情继续发生,或者出人意料

下面的代码生成了以下代码:

 {
"DAY": "TUESDAY",
"TIME": {
    "530": {
        "CLASSES": [
            {
                "CLASS": {
                    "INSTRUCTOR": "DANA",
                    "CLASS_LEVEL": "JUNIOR",
                    "MAX_STUDENTS": "8"
                }
            },
            {
                "CLASS": {
                    "STUDENTS": [
                        {
                            "STUDENT": [
                                {
                                    "FIRST NAME": "Alexandra",
                                    "LAST NAME": "",
                                    "DATE OF BIRTH": ""
                                }
                            ]
                        }
                    ]
                }
            },
            {
                "CLASS": {
                    "STUDENTS": [
                        {
                            "STUDENT": [
                                {
                                    "FIRST NAME": "Leivi",
                                    "LAST NAME": "",
                                    "DATE OF BIRTH": ""
                                }
                            ]
                        }
                    ]
                }
            },
            {
                "CLASS": {
                    "STUDENTS": [
                        {
                            "STUDENT": [
                                {
                                    "FIRST NAME": "Traivon",
                                    "LAST NAME": "",
                                    "DATE OF BIRTH": ""
                                }
                            ]
                        }
                    ]
                }
            },
            {
                "CLASS": {
                    "STUDENTS": [
                        {
                            "STUDENT": [
                                {
                                    "FIRST NAME": "Keira",
                                    "LAST NAME": "",
                                    "DATE OF BIRTH": ""
                                }
                            ]
                        }
                    ]
                }
            },
            {
                "CLASS": {
                    "STUDENTS": [
                        {
                            "STUDENT": [
                                {
                                    "FIRST NAME": "Madison",
                                    "LAST NAME": "",
                                    "DATE OF BIRTH": ""
                                }
                            ]
                        }
                    ]
                }
            },
但是,正如您所看到的,我希望“学生”嵌套在“类”下面。我做错了什么?我一辈子也弄不明白。我开始讨厌多维数组了-@

function dailySchedule() {
    global $conn;
    $sql = 'SET DATEFIRST 1

            SELECT [DAY].[DAY] AS [DAY], CLASS.CLASSTIME AS CLASSTIME, CLASSLEVEL.CLASSLEVEL AS CLASSLEVEL, CLASS.MAXSTUDENT AS MAXSTUDENT,
            INSTRUCTOR.FIRSTNAME AS INSTRUCTOR, STUDENT.FIRSTNAME AS STUDENTFIRST, STUDENT.SURNAME AS STUDENTLAST, STUDENT.DOB AS STUDENTDOB

            FROM STUDENT JOIN BOOKING ON STUDENT.ID = BOOKING.STUDENTID JOIN CLASS ON CLASS.ID = BOOKING.CLASSID JOIN CLASSLEVEL ON 
            CLASS.CLASSLEVELID = CLASSLEVEL.ID JOIN [DAY] ON CLASS.CLASSDAY = [DAY].ID JOIN INSTRUCTOR ON CLASS.INSTRUCTORID = INSTRUCTOR.ID

            WHERE   [DAY].ID = (DATEPART(dw, GETUTCDATE() AT TIME ZONE \'AUS Eastern Standard Time\'))

            ORDER BY CLASS.CLASSTIME ASC, INSTRUCTOR.FIRSTNAME ASC, CLASSLEVEL.CLASSLEVEL ASC';


    $studentDetails =
    $sqlEx = $conn->query($sql);
    $schedule = array();

    foreach($sqlEx as $rows) {

        if(!isset($day) || $day !== $rows['DAY']) {
            $day = $rows['DAY'];
            $schedule = array('DAY' => $day) + $schedule;
        }
        if(!isset($time) || $time !== $rows['CLASSTIME']) {
            $time = $rows['CLASSTIME'];
        }
        if(!isset($instructor) || $instructor !== $rows['INSTRUCTOR']) {
            $instructor = $rows['INSTRUCTOR'];
            $schedule['TIME'][$time]['CLASSES'][]['CLASS'] = [
                'INSTRUCTOR' => $instructor,
                'CLASS_LEVEL' => $rows['CLASSLEVEL'],
                'MAX_STUDENTS' => $rows['MAXSTUDENT'],
            ];
        }

        //if($instructor == $rows['INSTRUCTOR']){
            $schedule['TIME'][$time]['CLASSES'][]['CLASS']['STUDENTS'][]['STUDENT'][] = [
                    'FIRST NAME' => $rows['STUDENTFIRST'],
                    'LAST NAME' => $rows['STUDENTLAST'],
                    'DATE OF BIRTH' => $rows['STUDENTDOB']
                    ];


        //}

    }
    echo json_encode($schedule, JSON_PRETTY_PRINT);
}


提前谢谢大家。

我不确定这是你想要的还是不想要的,但我会用另一种方式:

$schedule = array();

    foreach($sqlEx as $rows) {

       $Day = $rows["DAY"];
       $ClassTime = $rows["CLASSTIME"];
       $ClassLevel = $rows["CLASSLEVEL"];
       $MaxStudents = $rows["MAXSTUDENTS"];
       $Instructor = $rows["INSTRUCTOR"];
       $StudentFirst = $rows["STUDENTFIRST"];
       $StudentLast = $rows["STUDENTLAST"];
       $StudentDOB = $rows["STUDENTDOB"];


       $schedule[$Day][$ClassTime]["CLASS"] = array("INSTRUCTOR" => $Instructor,"CLASS_LEVEL" =>$ClassLevel,"MAX_SUTENTS" => $MaxStudents);
       $schedule[$Day][$ClassTime]["STUDENT"] = array("FIRSTNAME" => $StudentFirst ,"LASTNAME" => $StudentLast, "DATE OF BIRTH" => $StudentDOB);

    }

    echo json_encode($schedule, JSON_PRETTY_PRINT);
你应该看一看