如何使用IF语句使用CSV中的值填充列

时间:2012-03-15 21:14:56

标签: php mysql excel csv

我的脚本需要帮助。我上传的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);
  ?>

感谢您的帮助。 注意:请原谅我的格式和缩进。我的意思是对这个社区没有任何不尊重。 感谢

1 个答案:

答案 0 :(得分:0)

使用MySQL Case

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'