new importfiles

This commit is contained in:
Marko 2023-02-28 11:27:27 +01:00
parent 9bf0994b25
commit 48230c73a6
No known key found for this signature in database
6 changed files with 41 additions and 24 deletions

View File

@ -8,13 +8,13 @@
<jdbc-url>jdbc:mysql://127.0.0.1:3306</jdbc-url> <jdbc-url>jdbc:mysql://127.0.0.1:3306</jdbc-url>
<working-dir>$ProjectFileDir$</working-dir> <working-dir>$ProjectFileDir$</working-dir>
</data-source> </data-source>
<data-source source="LOCAL" name="DDEV" uuid="b6d8fd7a-dc7c-4d77-a130-438821ee9c9c"> <data-source source="LOCAL" name="DDEV" uuid="096edb5d-73f9-4ef4-b462-f3f8e939a139">
<driver-ref>mariadb</driver-ref> <driver-ref>mariadb</driver-ref>
<synchronize>true</synchronize> <synchronize>true</synchronize>
<configured-by-url>true</configured-by-url> <configured-by-url>true</configured-by-url>
<remarks>DDEV generated data source</remarks> <remarks>DDEV generated data source</remarks>
<jdbc-driver>org.mariadb.jdbc.Driver</jdbc-driver> <jdbc-driver>org.mariadb.jdbc.Driver</jdbc-driver>
<jdbc-url>jdbc:mariadb://127.0.0.1:64102/db?user=db&amp;password=db</jdbc-url> <jdbc-url>jdbc:mariadb://127.0.0.1:32836/db?user=db&amp;password=db</jdbc-url>
<working-dir>$ProjectFileDir$</working-dir> <working-dir>$ProjectFileDir$</working-dir>
</data-source> </data-source>
</component> </component>

View File

@ -19,15 +19,11 @@ Starte MySQL-Server:
> docker compose up > docker compose up
Erstelle Datenbank (nicht die Tabellen) Erstelle Datenbank (nicht die Tabellen)
> bin/console doctrine:database:create > bin/console doctrine:database:create
>
Erstelle Tabellen Erstelle Tabellen
> bin/console doctrine:migrations:migrate > bin/console doctrine:migrations:migrate
Erstellen der Tabellen
> bin/console doctrine:migrations:migrate
Update der Datenbank Update der Datenbank
> bin/console doctrine:migrations:execute > bin/console doctrine:migrations:execute

View File

@ -62,7 +62,7 @@ class HiltesImportCommand extends Command
$r = $hiltesImport->startImport(); $r = $hiltesImport->startImport();
if($r['error']){ if(isset($r['error'])){
$io->error($r['text']); $io->error($r['text']);
$this->logger->error($r['text']); $this->logger->error($r['text']);
return Command::FAILURE; return Command::FAILURE;

View File

@ -113,10 +113,10 @@ class HiltesImport
// Header überspringen // Header überspringen
$c++; $c++;
#*** Convertiert die Zeile in UTF8 #*** Convertiert die Zeile in UTF8
//$str = iconv('ISO-8859-1','UTF-8',$file->fgets()); $data = iconv('ISO-8859-1','UTF-8',$file->fgets());
#*** Zerlegt die Zeile ********** #*** Zerlegt die Zeile **********
$data = $file->fgets(); //$data = $file->fgets();
if($c <= 1){ continue; } if($c <= 1){ continue; }
$this->switchSaveData($this->splitLine($data)); $this->switchSaveData($this->splitLine($data));
@ -212,29 +212,44 @@ class HiltesImport
} }
/**
* @param string $wareHouseName
* @return Warehouse|false|int|mixed|null
*/
private function checkWareHouseName(string $wareHouseName){ private function checkWareHouseName(string $wareHouseName){
#*** WEnn keine geCached Id Vorhanden #*** WEnn keine geCached Id Vorhanden
$warehouse2 = false;
if(empty($this->cachedWarehouseIds[$wareHouseName])){ if(empty($this->cachedWarehouseIds[$wareHouseName])){
#*** Check #*** Check
$warehouse2 = $this->warehouseRepository->findOneBy(['id'=> (int)$wareHouseName]); $warehouse2 = $this->warehouseRepository->findOneBy(['id'=> (int)$wareHouseName]);
#dump($warehouse2); //dump($warehouse2);
if(empty($warehouse2)){ if(empty($warehouse2)){
$warehouse = new Warehouse(); $warehouse = new Warehouse();
$warehouse->setId((int)$wareHouseName); $warehouse->setId((int)$wareHouseName);
$warehouse->setName($wareHouseName); $warehouse->setName($wareHouseName);
# #
$this->warehouseRepository->save($warehouse,true);
$this->warehouseRepository->save($warehouse,true);
$this->cachedWarehouseIds[$wareHouseName] = $warehouse;
#***************** #*****************
$warehouse2 = $this->warehouseRepository->findOneBy(['id'=> (int)$wareHouseName]); #$warehouse2 = $this->warehouseRepository->findOneBy(['id'=> (int)$wareHouseName]);
#dump($warehouse2); #dump($warehouse2);
} }else{
$this->cachedWarehouseIds[$wareHouseName] = $warehouse2; $this->cachedWarehouseIds[$wareHouseName] = $warehouse2;
}
} }
if(!empty($this->cachedWarehouseIds[$wareHouseName])) if(!empty($this->cachedWarehouseIds[$wareHouseName]))
return $this->cachedWarehouseIds[$wareHouseName]; return $this->cachedWarehouseIds[$wareHouseName];
return false; return false;
} }
/**
* @param string $gtin
* @param string $modellNr
* @param string $modellBez
* @return false|int|mixed|null
*/
private function checkProduct(string $gtin,string $modellNr,string $modellBez){ private function checkProduct(string $gtin,string $modellNr,string $modellBez){
#*** WEnn keine geCached Id Vorhanden #*** WEnn keine geCached Id Vorhanden
if(empty($this->cachedProdIds[$gtin])){ if(empty($this->cachedProdIds[$gtin])){
@ -244,16 +259,18 @@ class HiltesImport
if(empty($prod2)){ if(empty($prod2)){
$prod = new Product(); $prod = new Product();
$prod->setGtin($gtin); $prod->setGtin($gtin);
$prod->setModellNr($modellNr); $prod->setModellNr(trim($modellNr));
$prod->setModellBez($modellBez); $prod->setModellBez(trim($modellBez));
$prod->setShopwareId(""); $prod->setShopwareId("");
# #
$this->productRepository->save($prod,true); $this->cachedProdIds[$gtin] = $this->productRepository->save($prod,true);
#***************** #*****************
$prod2 = $this->productRepository->findOneBy(['gtin'=> $gtin]); //$prod2 = $this->productRepository->findOneBy(['gtin'=> $gtin]);
#dump($warehouse2); #dump($warehouse2);
} }else{
$this->cachedProdIds[$gtin] = $prod2->getId(); $this->cachedProdIds[$gtin] = $prod2->getId();
}
} }
if(!empty($this->cachedProdIds[$gtin])) if(!empty($this->cachedProdIds[$gtin]))
return $this->cachedProdIds[$gtin]; return $this->cachedProdIds[$gtin];

View File

@ -21,7 +21,7 @@ class ProductRepository extends ServiceEntityRepository
parent::__construct($registry, Product::class); parent::__construct($registry, Product::class);
} }
public function save(Product $entity, bool $flush = false): void public function save(Product $entity, bool $flush = false): ?int
{ {
$entity->setUpdateTime(new \DateTime()); $entity->setUpdateTime(new \DateTime());
@ -31,6 +31,8 @@ class ProductRepository extends ServiceEntityRepository
if ($flush) { if ($flush) {
$this->getEntityManager()->flush(); $this->getEntityManager()->flush();
} }
return $entity->getId();
} }
public function remove(Product $entity, bool $flush = false): void public function remove(Product $entity, bool $flush = false): void

View File

@ -21,7 +21,7 @@ class WarehouseRepository extends ServiceEntityRepository
parent::__construct($registry, Warehouse::class); parent::__construct($registry, Warehouse::class);
} }
public function save(Warehouse $entity, bool $flush = false): void public function save(Warehouse $entity, bool $flush = false): ?int
{ {
$entity->setPrio(0); $entity->setPrio(0);
$this->getEntityManager()->persist($entity); $this->getEntityManager()->persist($entity);
@ -29,6 +29,8 @@ class WarehouseRepository extends ServiceEntityRepository
if ($flush) { if ($flush) {
$this->getEntityManager()->flush(); $this->getEntityManager()->flush();
} }
return $entity->getId();
} }
public function remove(Warehouse $entity, bool $flush = false): void public function remove(Warehouse $entity, bool $flush = false): void