40 lines
		
	
	
	
		
			1.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			40 lines
		
	
	
	
		
			1.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| use Illuminate\Database\Seeder;
 | |
| use League\Csv\Reader;
 | |
| use App\Proveedor;
 | |
| 
 | |
| class ProductoSeeder extends Seeder
 | |
| {
 | |
|     /**
 | |
|      * Run the database seeds.
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function run()
 | |
|     {
 | |
|         $csv = Reader::createFromPath(resource_path('csv/productos.csv'), 'r');
 | |
|         $csv->setDelimiter("|");
 | |
|         $csv->setEnclosure("'");
 | |
|         $csv->setHeaderOffset(0);
 | |
|         $registros = $csv->getRecords();
 | |
|         $toInsert = [];
 | |
| 
 | |
|         foreach($registros as $registro){
 | |
|             $toInsert[] = [
 | |
|                 'categoria'        => $registro['categoria'],
 | |
|                 'nombre'        => $registro['producto'],
 | |
|                 'precio'      => $registro['precio'],
 | |
|                 'proveedor_id' => isset($registro['proveedor']) ? Proveedor::firstOrCreate([
 | |
|                     'nombre' => $registro['proveedor']
 | |
|                 ])->id : null,
 | |
|                 'bono'  => $registro['categoria'] == 'BONOS Y FINANCIAMIENTO SORORO'
 | |
|             ];
 | |
|         }
 | |
| 
 | |
|         foreach (array_chunk($toInsert,DatabaseSeeder::CHUNK_SIZE) as $chunk)  
 | |
|         {
 | |
|             DB::table('productos')->insert($chunk); 
 | |
|         }
 | |
|     }
 | |
| }
 | 
