<?php class CourseStudentTableSeeder extends Seeder { public function run() { // Disable query logging to avoid memory exhaustion DB::disableQueryLog(); $this->command->info('-----------------------------------------'); $this->command->info('-----------------------------------------'); $this->command->info('Course student table seeding started...'); // Initiates time $time_start = microtime(true); // Open file if($file = fopen('app/database/csv/estudiante_curso.csv', 'r')) { // Initialize count variables $read = 0; $added =0; $updated = 0; $error = 0; $semester_id = NULL; // Read each row while($data = fgetcsv($file, 5000)) // se cambio delimitador para evitar problemas con nombre separados del apellido con coma { // Add read count $read++; try { $student_number = trim($data[1]); $code_number_section = trim($data[2]); $term_code = trim($data[3]); // If any required field is empty, raise an exception if(!$code_number_section || !$student_number || !$term_code) { throw new Exception('WARNING (line '.($read+1).'): Missing information, read \''.implode(",", $data).'\''); } if(!$semester_id) { // Get semester $semester_id = Semester::select('id')->where('code', strtoupper($term_code))->first()['id']; // If semester code is not in the first line, abort script if(!$semester_id) { $this->command->info('FATAL ERROR(line '.$read.'): The semester code (i.e. B71) is required. Please check the file. Field contents: \''.$term_code.'\''); exit(); } } // Get row info $course = Course::select('id')->where('code', trim(substr($code_number_section, 0, 4)))->where('number', trim(substr($code_number_section, 4, 4)))->where('section', trim(substr($code_number_section, 8, 3)))->where('semester_id', $semester_id)->first(); $student_id = Student::select('id')->where('number', trim($student_number))->first()['id']; // If information is incorrect or not present in the database, raise an exception if(!$course['id']) { throw new Exception('WARNING (line '.($read+1).'): Course '.$code_number_section.' not found in the database.'); } if(!$student_id) { throw new Exception('WARNING (line '.($read+1).'): Student '.$student_number.' not found in the database.'); } // If course-student combination exists, touch the timestamp if(DB::table('course_student')->where('course_id', $course->id )->where('student_id', $student_id)->count()) { $course->students()->updateExistingPivot($student_id, array('updated_at' => date("Y-m-d H:i:s", time()))); // $this->command->info('Touched (line '.($read+1).'): ['.$student_number.', '.$code_number_section.'].'); $updated++; } // Otherwise, add the combination else { // Assign student to course $course->students()->attach($student_id, array('semester_id' => $semester_id)); $this->command->info('Added (line '.($read+1).'): ['.$student_number.', '.$code_number_section.'].'); } $added++; } // If an exception is raised, show the message and add to error catch(Exception $e) { $this->command->info($e->getMessage()); $error++; }; } // Delete all inactive users for current term DB::table('course_student') ->where('updated_at', '<', date('Y-m-d')) ->where('semester_id', $semester_id) ->delete(); // Stop time $time_end = microtime(true); // Display results $this->command->info('------------------------------------------------------------'); $this->command->info('Results on '.date('M d, Y, h:i:s a')); $this->command->info('- Runtime: '.(round($time_end - $time_start, 3)).' seconds'); $this->command->info('- Read: '.$read); $this->command->info('- Updated (active): '.$updated); $this->command->info('- Added: '.$added); $this->command->info('- Not added (errors or missing information): '.($error)); // Close file fclose($file); } // File cannot be opened, display error and exit else { $this->command->info('File '.$filename.' could not be opened. Make sure it is located in the app/database/csv directory of this project.'); } } }