其他分享
首页 > 其他分享> > 教义2类表继承YML

教义2类表继承YML

作者:互联网

我正在尝试在ZF2和Doctrine 2中使用“类表继承”.我的实现非常简单.我认为我已经设置了所有的类结构,但是我认为某些地方的设置可能存在问题.不幸的是,我在Class设置上找到了很多文档,但是在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

解决方法:

上面的所有内容都完全有效并且可以正常工作.看来我没有为客户注释单元测试包括注释夹具数据,反之亦然.因此,我愚蠢地呆了几天.

标签:doctrine-orm,zend-framework2,class-table-inheritance,php
来源: https://codeday.me/bug/20191030/1967948.html