Класс переопределения Order в исключении sylius, вызывающем «sylius_order», уже существует - PullRequest
0 голосов
/ 07 сентября 2018

Я пытаюсь добавить новое поле в таблицу заказов. Но переопределение вызывает ошибку, как будто таблица уже существует. Я пытался следить за https://github.com/Sylius/Sylius/issues/3997 вопросом. но не повезло.

Моя сущность

   <?php

namespace Goldco\Entity;

use Doctrine\ORM\Mapping as ORM;
use Sylius\Component\Order\Model\Order as BaseOrder;//Sylius\Component\Core\Model\Order as BaseOrder;
use Sylius\Component\Order\Model\OrderItemUnitInterface;

/**
 * Order
 *
 * @ORM\Table(name="sylius_order")
 * @ORM\Entity
 */
class Order extends BaseOrder
{


    /**
     * @var string|null
     *
     * @ORM\Column(name="quantity_decimal", type="decimal", precision=12, scale=4, nullable=true, options={"comment"="decimal quantity"})
     */
    private $quantityDecimal;



}

Файл конфигурации:

sylius_order:
    resources:
        order_item:
            classes:
                model: Goldco\Entity\SyliusOrderItem
                controller : Goldco\Controller\App\OrderItemController
        order:
            classes:
                model: Goldco\Entity\Order
                controller: Sylius\Bundle\CoreBundle\Controller\OrderController
                repository: Sylius\Bundle\CoreBundle\Doctrine\ORM\OrderRepository

А orm.yml

Goldco\Entity\Order:
    type: entity
    table: sylius_order
    fields:
        quantityDecimal:
            type: decimal
            nullable: true
            precision: 12
            scale: 4
            options:
                comment: 'decimal quantity'
            column: quantity_decimal
    lifecycleCallbacks: {  }

При выполнении команды orm я получаю сообщение об ошибке:

 The table with name 'eco_latest.sylius_order' already exists.

что-нибудь здесь отсутствует в конфиге?

Редактировать:

 $this->addSql('CREATE TABLE SyliusOrder (id INT AUTO_INCREMENT NOT NULL, number VARCHAR(255) DEFAULT NULL, notes LONGTEXT DEFAULT NULL, state VARCHAR(255) NOT NULL, checkout_completed_at DATETIME DEFAULT NULL, items_total INT NOT NULL, adjustments_total INT NOT NULL, total INT NOT NULL, created_at DATETIME NOT NULL, updated_at DATETIME DEFAULT NULL, currency_code VARCHAR(3) NOT NULL, locale_code VARCHAR(255) NOT NULL, checkout_state VARCHAR(255) NOT NULL, payment_state VARCHAR(255) NOT NULL, shipping_state VARCHAR(255) NOT NULL, token_value VARCHAR(255) DEFAULT NULL, customer_ip VARCHAR(255) DEFAULT NULL, invoice_no VARCHAR(100) DEFAULT NULL, invoice_file_path VARCHAR(100) DEFAULT NULL, UNIQUE INDEX UNIQ_3458A6D996901F54 (number), PRIMARY KEY(id)) DEFAULT CHARACTER SET UTF8 COLLATE UTF8_unicode_ci ENGINE = InnoDB');

И syliusorder таблица была создана в моей БД. Я не уверен, нужно ли что-либо настраивать, чтобы это исправить.

Ответы [ 2 ]

0 голосов
/ 11 февраля 2019

В orm.yml измените тип с entity на mappedSuperclass

Goldco\Entity\Order: type: mappedSuperclass table: sylius_order ...

0 голосов
/ 18 декабря 2018

Настроенный класс должен быть отображенным суперклассом. Используйте следующие аннотации:

/**
 * @ORM\MappedSuperclass
 * @ORM\Table(name="sylius_order")
 * @ORM\Entity
 */
...