<?php class ProgramUserTableSeeder extends Seeder { public function run() { // Disable query logging to avoid memory exhaustion // SELECT DISTINCT `program_id` , `user_id` FROM `courses` DB::disableQueryLog(); $this->command->info('Program_Users table seeding started...'); // Initiates time $time_start = microtime(true); // Open file if($file = fopen('app/database/csv/programs_users.csv', 'r')) { // Initialize count variables $read = 0; $added = 0; $deleted = 0; $error = 0; // Read each row while($data = fgetcsv($file, 5000, ",")) { // Add read count $read++; try { // Get row info $program_id = trim($data[0]); $user_id = trim($data[1]); // Missing data trow exception if(!$program_id || !$user_id){ throw new Exception('NON-FATAL ERROR(line '.$read.'): Missing information, read \''.implode(",", $data).'\''); } // If user has default 999 program, delete and insert rows if(DB::table('program_user')->where('program_id', '=', 999)->where('user_id', '=', $user_id)->get()){ $this->command->info('Would had deleted default program if not needed verify down for new program insert or inserts: user_id = '.$user_id); // Delete from table program_user default program DB::table('program_user')->where('program_id', '=', 999)->where('user_id', '=', $user_id)->delete(); $deleted++; // Insert new program_user row if it doesnt exist if(!(DB::table('program_user')->where('program_id', '=', $program_id)->where('user_id', '=', $user_id)->get())){ DB::table('program_user')->insert(array('program_id' => $program_id, 'user_id' => $user_id)); $this->command->info('Insert after deleting default program for user_id = '.$user_id); $added++; } }else{ // Insert new program_user row if it doesnt exist if(!(DB::table('program_user')->where('program_id', '=', $program_id)->where('user_id', '=', $user_id)->get())){ DB::table('program_user')->insert(array('program_id' => $program_id, 'user_id' => $user_id)); $this->command->info('Insert new line, no default program for user_id = '.$user_id); $added++; } } } // If an exception is raised, show the message and add to error catch(Exception $e) { $this->command->info($e->getMessage()); $error++; }; } // 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('- Deleted default programs from users (999): '.$deleted); $this->command->info('- Added (new active): '.$added); $this->command->info('- Not added/updated (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.'); } } }