8
0
ModCfg/Application/Model/Maintenance/Actions/AccessioreToArticleOrphans.php

93 Zeilen
2.6 KiB
PHP

2024-04-19 16:15:46 +02:00
<?php
/**
2024-09-02 08:48:43 +02:00
* Copyright (c) D3 Data Development (Inh. Thomas Dartsch)
*
* For the full copyright and license information, please view
* the LICENSE file that was distributed with this source code.
*
* https://www.d3data.de
2024-04-19 16:15:46 +02:00
*
* @copyright (C) D3 Data Development (Inh. Thomas Dartsch)
2024-09-02 08:48:43 +02:00
* @author D3 Data Development - Daniel Seifert <info@shopmodule.com>
* @link https://www.oxidmodule.com
2024-04-19 16:15:46 +02:00
*/
declare(strict_types=1);
namespace D3\ModCfg\Application\Model\Maintenance\Actions;
use Doctrine\DBAL\Driver\Exception as DoctrineDriverException;
use Doctrine\DBAL\Exception as DoctrineException;
use Doctrine\DBAL\Query\QueryBuilder;
use Psr\Container\ContainerExceptionInterface;
use Psr\Container\NotFoundExceptionInterface;
class AccessioreToArticleOrphans extends AbstractAction
{
/**
* @return int
* @throws ContainerExceptionInterface
* @throws DoctrineDriverException
* @throws DoctrineException
* @throws NotFoundExceptionInterface
*/
public function getAffectedRows(): int
{
$queryBuilder = $this->getBaseQuery('a2a');
$queryBuilder->select('count(*)')
->setMaxResults(1);
return (int) $queryBuilder->execute()->fetchOne();
}
/**
* @throws ContainerExceptionInterface
* @throws DoctrineDriverException
* @throws DoctrineException
* @throws NotFoundExceptionInterface
*/
public function fixIt(): void
{
$this->fixAction(
$this->getBaseQuery('a2a'),
'a2a.oxid',
'oxaccessoire2article',
'D3_CFG_CLRTMP_ASSIGNACC2ART_SUCC'
);
}
/**
* @param string $tableAlias
*
* @return QueryBuilder
* @throws ContainerExceptionInterface
* @throws NotFoundExceptionInterface
*/
protected function getBaseQuery(string $tableAlias): QueryBuilder
{
$queryBuilder = $this->getQueryBuilder();
$queryBuilder
->from('oxaccessoire2article', $tableAlias)
->leftJoin(
$tableAlias,
'oxarticles',
'art',
$queryBuilder->expr()->eq($tableAlias.'.oxarticlenid', 'art.oxid')
)
->leftJoin(
$tableAlias,
'oxarticles',
'acc',
$queryBuilder->expr()->eq($tableAlias.'.oxobjectid', 'acc.oxid')
)
->where(
$queryBuilder->expr()->or(
$queryBuilder->expr()->isNull('art.oxid'),
$queryBuilder->expr()->isNull('acc.oxid')
)
);
return $queryBuilder;
}
}