使用php在数组中输入/覆盖信息

zvokhttg  于 2021-06-23  发布在  Mysql
关注(0)|答案(1)|浏览(284)

我有一个小的php页面,它从mysql获取数据,并通过php在月历中显示。我无法在数组中正确排列数据以获得所需的输出。
首先,我将描述我希望发生的事情:
学生们在一周的固定时间来上课
他们也可以预订或取消预订
日历还显示学校不开放的日子
为了在日历上显示这些数据,我使用mysql从各种来源输出数据,然后用php将数据输入到一个数组中,然后按日期排序并输出。
我的问题是,我希望每天能够处理多行数据,但由于我使用的是日期作为键,我每天只能显示一个结果受到限制。如果我使用循环在键中添加一个计数器来添加日期,那么在有人进行了预订,然后在同一天取消了预订的情况下,会得到重叠的结果。
至于我的密码。。。
首先,我检查该学生是否在每周的课程中注册,然后将该课程输入数组。

$sql = "SELECT StudentDB.studentid, ClassDB.classID, ClassDB.class_level, ClassDB.class_title, ClassDB.time, ClassDB.teacher, StudentDB.first_name, StudentDB.last_name, StudentDB.payment_amount, ClassDB.day 
            FROM ClassDB 
            INNER JOIN RegDB ON ClassDB.classID = RegDB.classid 
            INNER JOIN StudentDB ON StudentDB.studentID = RegDB.studentid 
            WHERE StudentDB.studentid = '$studentid'";

    $result = $conn->query($sql);

    if ($result->num_rows > 0) {

      while($row = $result->fetch_assoc()) {   // DISPLAY REGULAR CLASS DATA

        $dayofclass = $row['day'];
        $class_level = $row['class_level'];
        $class_title = $row["class_title"];
        $day = $row["day"];
        $class_time = $row["class_time"];
        $time = $row["time"];

        // check which dates match the days of the week and store in an array

        for ($i=1;$i<=$n;$i++){

          if ($i<10) {
            $i = "0" . $i;
          }

          $day=date("l",strtotime($yearmonth.$i)); //find weekdays

          if($day==$dayofclass){
            $time = date("H:i",strtotime($row['time']));
            $dates[]=$yearmonth.$i;
            $datesdata[$yearmonth.$i] = "0";
            $timedata[$yearmonth.$i] = $time;
            $classiddate[$yearmonth.$i] = $row['classID'];
          }
        }
     }
      echo "</table>";
      $conn->close();
    }

之后,我检查特定的预订(取消、不规则预订、等待列表),并将它们输入到数组中:

$lowerlimit = $yearmonth . "01";
    $upperlimit = $yearmonth . "31";

    $sql = "SELECT AttendanceDB.*, ClassDB.* 
    FROM StudentDB 
    INNER JOIN AttendanceDB ON StudentDB.studentid = AttendanceDB.studentid 
    INNER JOIN ClassDB ON AttendanceDB.classid = ClassDB.classID
    WHERE StudentDB.studentid = '$studentid' 
    AND AttendanceDB.class_time >= '$lowerlimit'
    AND AttendanceDB.class_time <= '$upperlimit'";

    $result = $conn->query($sql);

    if ($result->num_rows > 0) {  

      $loopcount = 0;

      // store furikae data in the array
      while($row = $result->fetch_assoc()) {  

        $phpdate = strtotime( $row["class_time"] );
        $time = date("H:i",strtotime($row['time']));
        $mysqldate = date( 'Y-m-d', $phpdate );
        $loopcount++;
        $mysqldate = $mysqldate . "+" . $loopcount;

//            $loopcount++;
//            $mysqldate = $mysqldate . "+" . $loopcount;

        $previousdate = $mysqldate;
        $previousfurikae = $row['furikae'];

        if ($row["furikae"] == 3){
          $dates[]=$mysqldate;
          $datesdata[$mysqldate] = "1";
          $timedata[$mysqldate] = $time;
          $classiddate[$mysqldate] = $row['classID'];
        } elseif ($row["furikae"] == 8 OR $row["furikae"] == 7) {
          $dates[]=$mysqldate;
          $datesdata[$mysqldate] = "3";
          $timedata[$mysqldate] = $time;
        } elseif ($row["furikae"] == 2) {
          $dates[]=$mysqldate;
          $datesdata[$mysqldate] = "2";
          $timedata[$mysqldate] = $time;
        }              
      }
    } 

    $conn->close();

最后,我检查了学校日历,并将休息日输入到数组中:

$sql = "SELECT * 
    FROM SchoolScheduleDB 
    WHERE date >= '$lowerlimit'
    AND date <= '$upperlimit'";

    $result = $conn->query($sql);

    if ($result->num_rows > 0) {  

      // store furikae data in the array
      while($row = $result->fetch_assoc()) {  

        $phpdate = strtotime( $row["date"] );
//            $time = date("H:i",strtotime($row['time']));
//            $mysqldate = date( 'Y-m-d', $phpdate ) . " " . $time;
          $mysqldate = date( 'Y-m-d', $phpdate );
          $dates[]=$mysqldate;
          $datesdata[$mysqldate] = "666";

      }
    } 

    $conn->close();

我打算这样做:
首先输入常规类
那么任何保留都会覆盖原来的计划
最后学校的日历会覆盖一切
目前,它的功能,因为它应该,但它限于显示一个结果,每天,但我想能够显示一个以上的学生谁来到多个班级每天的结果。
谢谢你的帮助。如果我的问题有任何错误或我的问题不清楚,我会尽力修改它。

3bygqnnd

3bygqnnd1#

您可以使用带边框的括号为每个日期创建子数组:

$data[20180528][] = 'aa';
$data[20180528][] = 'bb';
$data[20180529][] = 'cc';
$data[20180529][] = 'dd';
$data[20180529][] = 'ee';

会给你一个这样的数组:

20180528 => aa
         => bb

20180529 => cc
         => dd
         => ee

相关问题