我的脚本需要帮助。我上传的CSV文件有两列matric_no和得分。问题在于我试图在维护人员中填写成绩列,具体取决于每一行得分列中上传的内容。如果得分> 70,则成绩值应为A,依此类推。我的维护结构是
MAINTABLE
score_id
matric_no
score
grade
course_code
level
semester_name
session
最后四列是来自界面的用户输入值,我想要动态生成等级。
谢谢
<?php
$fname = $_FILES['csv_file']['name'];
$chk_ext = explode(".",$fname);
$filename = $_FILES['csv_file']['tmp_ name'];
$handle = fopen($filename, "r");
if(!$handle){
die ('Cannot open file for reading');
}
while (($data = fgetcsv($handle, 10000, ",")) !== FALSE)
{
$query = "INSERT INTO maintable (matric_no, score, session, semester_ name, course_code, level)
values('$data[0]', '$data[1]', '". $session."', '".$semester_name."', '". $course_code."', '".$level."')
ON DUPLICATE KEY UPDATE matric_no = matric_no";
mysql_query($query) or die(mysql_error ());
}
if ($row['score'] >= 70) {
$grade = 'A';
}
elseif ($row['score'] >= 60) {
$grade = 'B';
}elseif ($row['score'] >= 50) {
$grade = 'C';
}elseif ($row['score'] >= 45) {
$grade = 'D';
}elseif($row['score'] >= 40) {
$grade = 'E';
}else{
$grade = 'F';
}
$query = "UPDATE maintable
SET grade = 'A' WHERE score >= 70,
SET grade = 'B' WHERE score >= 60 AND score < 70 ,
SET grade = 'C' WHERE score >= 50 AND score < 60,
SET grade = 'D' WHERE score >= 45 AND score < 50,
SET grade = 'E' WHERE score >= 40 AND score < 45 ,
SET grade = 'F' WHERE score < 40" mysql_query($query) or die(mysql_error ());
fclose($handle);
?>
感谢您的帮助。 注意:请原谅我的格式和缩进。我的意思是对这个社区没有任何不尊重。 感谢
答案 0 :(得分:0)
UPDATE maintable
SET grade = CASE
WHEN score >= 70 THEN 'A'
WHEN score >= 60 THEN 'B'
WHEN score >= 50 THEN 'C'
WHEN score >= 40 THEN 'D'
WHEN score >= 30 THEN 'E'
ELSE 'F'