Мне нужна помощь с моим сценарием.Я загружаю файл CSV, который имеет два столбца matric_no и счет.Проблема заключается в том, что я пытаюсь заполнить столбец оценок в основной таблице записями в зависимости от того, что загружено в каждый ряд столбца оценок. Если оценка> 70, значение в оценках должно быть А и так далее.Структура моей основной таблицы:
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);
?>
Спасибо за помощь.ПРИМЕЧАНИЕ: Пожалуйста, прости мое форматирование и отступы.Я не имел в виду неуважение к этому сообществу.Спасибо