как обновить данные в базе данных с помощью Excel Excel. я использую laravel 5.7 и maatwebsite 3.1
это мой контроллер:
public function import()
{
$data = Excel::toArray(new ProdukImport, request()->file('file'));
if ($data) {
DB::table('produk')
->where('id_produk', $data['id'])
->update($data);
}
}
Это мой класс импорта:
<?php
namespace App\Imports;
use App\Produk;
use Maatwebsite\Excel\Concerns\ToModel;
use Maatwebsite\Excel\Concerns\WithHeadingRow;
class ProdukImport implements ToModel, WithHeadingRow
{
/**
* @param array $row
*
* @return \Illuminate\Database\Eloquent\Model|null
*/
public function model(array $row)
{
return new Produk([
'id_produk' => $row['id'],
'nama_produk' => $row['produk'],
'harga_jual' => $row['harga']
]);
}
}
результат этого дд ($ data):
array:1 [▼
0 => array:8 [▼
0 => array:3 [▼
"id" => 1.0
"produk" => "Pomade"
"harga" => 90000.0
]
1 => array:3 [▼
"id" => 2.0
"produk" => "Shampoo"
"harga" => 90000.0
]
2 => array:3 [▼
"id" => 3.0
"produk" => "Sikat WC"
"harga" => 90000.0
]
]
]
результат $ data получается из этого: $ data = Excel :: toArray (новый ProdukImport, request () -> file ('file'));