Doctrine 2 Class Table Inheritance YML
Я пытаюсь использовать наследование таблиц классов в ZF2 и Doctrine 2. Моя реализация довольно проста. Я думаю, что у меня есть вся структура классов, но я думаю, что где-то может быть проблема с какой-то настройкой. К сожалению, я нашел много документации по настройке класса, но не так много по реализации YML. Кажется, что все прибегают к использованию инструментов доктрины для генерации всего. С тем, как все настроено, использование инструментов доктрины немного проблематично, особенно при использовании ZF2. Кроме того, я считаю, что это возможность обучения. Итак, вот что у меня есть:
Текущая проблема: я не получаю никаких данных из дочернего класса / таблицы:
.array(1) {
[0] =>
class MyCompany\Domain\Model\Customer\CustomerNote#2852 (9) {
protected $customer =>
NULL
protected $note =>
string(13) "Clever Note 1"
protected $id =>
string(1) "1"
protected $disabled =>
NULL
protected $modified =>
class DateTime#2884 (3) {
...
Класс / Таблица родовых нот:
CREATE TABLE generic_notes
(
note_id serial NOT NULL,
discriminator character varying(255) NOT NULL,
note text,
created timestamp with time zone NOT NULL DEFAULT now(),
created_by_id bigint NOT NULL,
modified timestamp with time zone,
modified_by_id bigint,
disabled timestamp with time zone NOT NULL DEFAULT 'infinity'::timestamp with time zone,
CONSTRAINT generic_notes_pkey PRIMARY KEY (note_id),
CONSTRAINT generic_notes_created_by_id_fkey FOREIGN KEY (created_by_id)
REFERENCES users (user_id) MATCH SIMPLE
ON UPDATE CASCADE
ON DELETE RESTRICT,
CONSTRAINT generic_notes_modified_by_id_fkey FOREIGN KEY (modified_by_id)
REFERENCES users (user_id) MATCH SIMPLE
ON UPDATE CASCADE
ON DELETE RESTRICT
)
Класс / таблица примечаний клиента (наследует общие примечания):
CREATE TABLE customer_notes
(
note_id bigint NOT NULL,
customer_id bigint NOT NULL,
CONSTRAINT customer_notes_pkey PRIMARY KEY (note_id),
CONSTRAINT customer_notes_note_id_fkey FOREIGN KEY (note_id)
REFERENCES generic_notes (note_id) MATCH SIMPLE
ON UPDATE RESTRICT
ON DELETE RESTRICT,
CONSTRAINT customer_notes_customer_id_fkey FOREIGN KEY (customer_id)
REFERENCES customers (customer_id) MATCH SIMPLE
ON UPDATE R1ESTRICT
ON DELETE RESTRICT
)
Отображение YML для заметки:
MyCompany\Domain\Model\Note:
type: entity
table: generic_notes
inheritanceType: JOINED
discriminatorColumn:
name: discriminator
type: string
length: 255
discriminatorMap:
customer: MyCompany\Domain\Model\Customer\CustomerNote
id:
id:
column: note_id
type: bigint
generator:
strategy: IDENTITY
fields:
note:
type: text
nullable: true
created:
type: datetimetz
modified:
type: datetimetz
nullable: true
disabled:
type: datetimetz
nullable: true
manyToOne:
createdBy:
targetEntity: MyCompany\Domain\Model\User
joinColumn:
name: created_by_id
referencedColumnName: user_id
modifiedBy:
targetEntity: MyCompany\Domain\Model\User
joinColumn:
name: modified_by_id
referencedColumnName: user_id
Отображение заметки клиента:
MyCompany\Domain\Model\Customer\CustomerNote:
type: entity
table: customer_notes
manyToOne:
customer:
targetEntity: MyCompany\Domain\Model\Customer
inversedBy: customerNote
joinColumn:
name: customer_id
referencedColumnName: customer_id
Общая сущность примечания
<?php
namespace MyCompany\Domain\Model;
use MyCompany\Domain\Model\Entity\AbstractEntity;
use MyCompany\Domain\Model\Entity\DisabledTrait;
use MyCompany\Domain\Model\Entity\TimestampedInterface;
use MyCompany\Domain\Model\Entity\TimestampedTrait;
/**
* Class Note
*
* @package MyCompany\Domain\Model
*/
class Note extends AbstractEntity implements TimestampedInterface
{
use DisabledTrait;
use TimestampedTrait;
/**
* @var string
*/
protected $note;
/**
* @param string $note
* @return $this
*/
public function setNote($note)
{
$this->note = $note;
return $this;
}
/**
* @return string
*/
public function getNote()
{
return $this->note;
}
}
Примечание клиента
<?php
namespace MyCompany\Domain\Model\Customer;
use MyCompany\Domain\Model\Note;
use MyCompany\Domain\Model\Customer;
/**
* Class CustomerNote
* @package MyCompany\Domain\Model\Customer
*/
class CustomerNote extends Note
{
/**
* @var \MyCompany\Domain\Model\Customer
*/
protected $customer;
/**
* @param \MyCompany\Domain\Model\Customer $customer
* @return $this
*/
public function setCustomer(Customer $customer)
{
$this->customer = $customer;
return $this;
}
/**
* @return \MyCompany\Domain\Model\Customer
*/
public function getCustomer()
{
return $this->customer;
}
}
Общие данные для фиксации данных:
generic_notes:
-
note_id: 1
discriminator: customer
note: Clever Note 1
created: "2012-01-23 05:43:21.000000"
created_by_id: 1
modified: "2012-01-24 05:43:21.000000"
modified_by_id: 2
disabled: null
Данные по фиксации примечаний клиента:
customer_notes:
-
note_id: 1
customer_id: 1
1 ответ
Все вышеперечисленное прекрасно действует и работает. Похоже, что я не включил данные о своих записях для модульного теста заметок клиентов, и наоборот. Итак, через несколько дней я пойму свою глупость.