繁体   English   中英

在 PHP MySQL 中使用查询嵌套 IF

[英]Nested IF using query in PHP MySQL

我在此代码上遇到了问题。 它不会根据查询转到第三个条件。 我有 5 列可以使用。

AMIN AMOUT PMIN PMOUT 状态

如果没有该日期和学生的记录,则第一个条目会创建记录。 列:状态为 0 的 AMIN 它应该在列 AMOUT 和 STATUS 上更新为 1 接下来,应该更新状态为 2 的 PMIN 最后更新状态为 3 的 PMOUT。

此代码仅适用于 PMIN,然后更新 AMOUT 更新 PMIN。 它不会进入 PMOUT

我有这个代码:

<?php
    $sql ="SELECT * FROM attendance WHERE STUDENTID='$id' AND LOGDATE='$date'";
        $query=$conn->query($sql);
        if($query->num_rows>0){
            $sql1 ="SELECT * FROM attendance WHERE STUDENTID='$id' AND LOGDATE='$date' AND STATUS='1'";
            $query1=$conn->query($sql1);
            if($query1->num_rows>0){
                $sql2 ="SELECT * FROM attendance WHERE STUDENTID='$id' AND LOGDATE='$date' AND STATUS='2'";
                $query2=$conn->query($sql2);
                if($query2->num_rows>0){
                    $sql = "UPDATE attendance SET PMOUT='$time', STATUS='3' WHERE STUDENTID='$studentID' AND LOGDATE='$date'";
                    $query=$conn->query($sql);
                    $_SESSION['success'];
                }
                else{
                $sql = "UPDATE attendance SET PMIN='$time', STATUS='2' WHERE STUDENTID='$studentID' AND LOGDATE='$date'";
                $query=$conn->query($sql);
                $_SESSION['success'];
                }
            }
            else{
            $sql = "UPDATE attendance SET AMOUT='$time', STATUS='1' WHERE STUDENTID='$studentID' AND LOGDATE='$date'";
            $query=$conn->query($sql);
            
            }
        
        }else{
            $sql = "INSERT INTO attendance(STUDENTID,AMIN,LOGDATE,STATUS) VALUES('$studentID','$time','$date','0')";
            if($conn->query($sql) ===TRUE){
                 $_SESSION['success'];
            }else{
            $_SESSION['error'] = $conn->error;
            }   
        }

有一个更好的方法吗?

看来你需要:

  1. 按学生和日期创建唯一索引:
CREATE UNIQUE INDEX idx_student_date ON attendance (studentid, logdate);
  1. 使用下一个查询:
INSERT INTO attendance (studentid, logdate, amin, amout, pmin, pmout, status)
VALUES ($id, CURRENT_DATE, CURRENT_TIME, NULL, NULL, NULL, 0)
ON DUPLICATE KEY UPDATE
amout = CASE WHEN status = 0 THEN CURRENT_TIME ELSE amout END,
pmin = CASE WHEN status = 1 THEN CURRENT_TIME ELSE pmin END,
pmout = CASE WHEN status = 2 THEN CURRENT_TIME ELSE pmout END,
status = status + 1;

如果当前学生和日期的行不存在,则将创建该行,如果存在,则将根据您的算法进行更新。 不需要您在 PHP 中的嵌套 IF。


此外,我建议您更改必须与存储的数据匹配的数据类型。

  • logdate应该是DATE NOT NULL
  • amin, amout, pmin, pmout应该是TIME
  • status应该是TINYINT CHECK (status BETWEEN 0 AND 3)

小提琴

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM