7

我正在使用Doctrine 2.4作为 ORM在Symfony 2.3中开发应用程序。我使用的数据库引擎是PostgreSQL。在其他表中使用复合主键映射实体时遇到问题。这些键是相关键中的外键。

我的数据库中的表具有以下结构

CREATE TABLE public.establecimiento
(
  id_establecimiento integer NOT NULL,
  establecimiento character varying(100) NOT NULL,
  CONSTRAINT pk_establecimiento PRIMARY KEY (id_establecimiento )
)
WITH (
  OIDS=FALSE
);
CREATE TABLE public.establecimiento_sec
(
  id_establecimiento_sec integer NOT NULL,
  id_establecimiento integer NOT NULL,
  det_seccion character varying(40) NOT NULL,
  plano character varying(100),
  sector_ingreso character varying(254),
  sponsor_imagen_sec character varying(96000),
  CONSTRAINT pk_establecimientos_sec PRIMARY KEY (id_establecimiento_sec , id_establecimiento ),
  CONSTRAINT fk_establec_reference_establec FOREIGN KEY (id_establecimiento)
      REFERENCES public.establecimiento (id_establecimiento) MATCH SIMPLE
      ON UPDATE RESTRICT ON DELETE RESTRICT
)
WITH (
  OIDS=TRUE
);
CREATE TABLE public.establecimiento_sec_plano
(
  id_establecimiento_sec_plano integer NOT NULL,
  id_establecimiento_sec integer NOT NULL,
  id_establecimiento integer NOT NULL,
  det_plano character varying(512),
  cantidad integer NOT NULL,
  precio double precision,
  insert_charge double precision DEFAULT 0,
  descr character varying(254),
  CONSTRAINT pk_establecimiento_sec_plano PRIMARY KEY (id_establecimiento_sec_plano , id_establecimiento_sec , id_establecimiento ),
  CONSTRAINT fk_establecimiento_sec FOREIGN KEY (id_establecimiento, id_establecimiento_sec)
      REFERENCES public.establecimiento_sec (id_establecimiento, id_establecimiento_sec) MATCH SIMPLE
      ON UPDATE NO ACTION ON DELETE CASCADE
)
WITH (
  OIDS=FALSE
);

定义实体 establecimientoSecPlano,包含键 $establecimiento 和 $id_establecimiento_sec 的 $establecimientoSec 变量

//实体/EstablecimientosSecPlano

/**
 * @ORM\Id
 * @ORM\ManyToOne(targetEntity="Ticketway\PruebaBundle\Entity\EstablecimientosSec")
 * @ORM\JoinColumns(
 *      @ORM\JoinColumn(name="id_establecimiento_sec", referencedColumnName="id_establecimiento_sec"),
 *      @ORM\JoinColumn(name="id_establecimiento", referencedColumnName="id_establecimiento")) 
 */
private $establecimientoSec;

//实体/EstablecimientosSec

 /**
 * @ORM\Id
 * @ORM\ManyToOne(targetEntity="Ticketway\PruebaBundle\Entity\Establecimientos")
 * @ORM\JoinColumn(name="id_establecimiento", referencedColumnName="id_establecimiento") 
 */
private $establecimiento;

执行命令教义时:映射:导入我收到以下错误

[Doctrine\ORM\Mapping\MappingException] 无法将实体 'EstablecimientoSec' 与复合主键映射为另一个实体 'EstablecimientoSecPlano#idEstablecimiento' 的主键的一部分。

我想知道是否有任何方法可以在 symfony 中定义实体,而我不能用学说。

我可以以其他方式映射功能以使应用程序正常工作吗?

我希望我的问题被理解。谢谢

4

1 回答 1

2

您遇到了这个问题,因为您的复合外键是另一个表的复合主键。这不是一个好的开发实践,这就是 Doctrine 根本不支持它的原因,我强烈怀疑它永远不会支持。

解决方案1(首选):

将单个自动增量主键添加到EstablecimientosSec. 然后,您可以链接到该链接EstablecimientosSec.id

解决方案2:

如果绝对不可能更改数据库结构,请不要映射关系。相反,您可以EstablecimientosSec使用复合主键在单独的查询中获取相关实体。这不是一个完美的解决方案,但它可以在这些限制下工作。提示:避免在循环中查询相关对象。

于 2015-04-08T21:30:42.613 回答