У меня проблема с различиями, созданными с помощью команды doctrine: migrations: diff для унаследованных таблиц.Я не могу сгенерировать эти таблицы через запятую миграции, но напрямую с помощью сценария SQL.
Это сценарий SQL для родительской таблицы:
create table if not exists sensor
(
id integer not null
constraint sensor_pkey
primary key,
sensor_class integer
constraint fk_bc8617b0ab0f4377
references sensor_class,
name text,
manufacturer text,
status text,
mount text,
weight numeric(10, 2) default NULL :: numeric,
width numeric(10, 2) default NULL :: numeric,
height numeric(10, 2) default NULL :: numeric,
sensor_model integer,
type varchar(3) not null
);
Это сценарий SQL для одной унаследованной таблицы:
create table if not exists tir
(
no_px_height integer,
no_px_width integer,
bit_depth numeric(10, 2) default NULL :: numeric,
cooled numeric(10, 2) default NULL :: numeric,
radiometric numeric(10, 2) default NULL :: numeric,
single_shot_max_data_rage numeric(10, 2) default NULL :: numeric,
detector_size_h numeric(10, 2) default NULL :: numeric,
detector_size_w numeric(10, 2) default NULL :: numeric,
fov_h numeric(10, 2) default NULL :: numeric,
fov_w numeric(10, 2) default NULL :: numeric,
focal_length numeric(10, 2) default NULL :: numeric,
band_width_min numeric(10, 2) default NULL :: numeric,
band_width_max numeric(10, 2) default NULL :: numeric,
min_time_between_images numeric(10, 2) default NULL :: numeric
)
inherits (sensor);
У меня есть другие таблицы, которые наследуются от датчика, таблицы указаны в карте различения на объекте Sensor.
Это объект Sensor:
/**
* Sensor
*
* @ORM\Table(name="sensor")
* @ORM\Entity
* @ORM\InheritanceType("JOINED")
* @ORM\DiscriminatorColumn(name="type", type="string", length=3)
* @ORM\DiscriminatorMap({
* "TIR"="Tir",
* "RGB"="Rgb",
* "MLS"="Multispectral",
* "EOC"="VideoCamera"
* })
*/
abstract class Sensor
{
/**
* @var int
*
* @ORM\Column(name="id", type="integer", nullable=false)
* @ORM\Id
*/
public $id;
/**
* @var string|null
*
* @ORM\Column(name="name", type="text", nullable=true)
*/
public $name;
/**
* @var string|null
*
* @ORM\Column(name="manufacturer", type="text", nullable=true)
*/
public $manufacturer;
/**
* @var int|null
*
* @ORM\Column(name="sensor_model", type="integer", nullable=true)
*/
public $sensorModel;
others fields...
Это одна из унаследованных сущностей:
/**
* @ORM\Entity
* @ORM\Table(name="tir")
*/
class Tir extends Sensor
{
/**
* @var int|null
*
* @ORM\Column(name="no_px_height", type="integer", nullable=true)
*/
private $noPxHeight;
/**
* @var int|null
*
* @ORM\Column(name="no_px_width", type="integer", nullable=true)
*/
private $noPxWidth;
/**
* @var float|null
*
* @ORM\Column(name="bit_depth", type="decimal", precision=10, scale=2, nullable=true)
*/
private $bitDepth;
others fields.
Только не унаследованные поля.
Вывод различий миграции:
$this->addSql('ALTER TABLE tir DROP sensor_class');
$this->addSql('ALTER TABLE tir DROP name');
$this->addSql('ALTER TABLE tir DROP manufacturer');
$this->addSql('ALTER TABLE tir DROP status');
$this->addSql('ALTER TABLE tir DROP mount');
$this->addSql('ALTER TABLE tir DROP weight');
$this->addSql('ALTER TABLE tir DROP width');
$this->addSql('ALTER TABLE tir DROP height');
$this->addSql('ALTER TABLE tir DROP sensor_model');
$this->addSql('ALTER TABLE tir DROP type');
$this->addSql('ALTER TABLE tir ADD CONSTRAINT FK_A68DD960BF396750 FOREIGN KEY (id) REFERENCES sensor (id) ON DELETE CASCADE NOT DEFERRABLE INITIALLY IMMEDIATE');
$this->addSql('ALTER TABLE tir ADD PRIMARY KEY (id)');
Как предотвратить эти различия?