[英]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;
}
}
有一个更好的方法吗?
看来你需要:
CREATE UNIQUE INDEX idx_student_date ON attendance (studentid, logdate);
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.