【问题标题】:Error while generating entity with composite primary key使用复合主键生成实体时出错
【发布时间】:2011-12-17 16:29:50
【问题描述】:

我今天意识到我错过了我的一个实体。我生成了 XML 元数据,然后生成了实体。我尝试重新生成实体,但仍然没有成功地重新生成它。

该实体具有复合主键。并且该键的每个部分实际上都是外键。

SQL:

CREATE TABLE lajki (
    _wydarzenie_id INT NOT NULL,
    _uzytkownik_id INT NOT NULL,
    _lajk_data DATETIME NOT NULL,
    PRIMARY KEY (_wydarzenie_id, _uzytkownik_id),
    FOREIGN KEY (_uzytkownik_id) REFERENCES uzytkownicy(_uzytkownik_id),
    FOREIGN KEY (_wydarzenie_id) REFERENCES wydarzenia(_wydarzenie_id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE utf8_general_ci;

XML 元数据:

<?xml version="1.0" encoding="utf-8"?>
<doctrine-mapping xmlns="http://doctrine-project.org/schemas/orm/doctrine-mapping" 
                  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
                  xsi:schemaLocation="http://doctrine-project.org/schemas/orm/doctrine-mapping http://doctrine-project.org/schemas/orm/doctrine-mapping.xsd">
  <entity name="Lajki" table="lajki">
    <change-tracking-policy>DEFERRED_IMPLICIT</change-tracking-policy>
    <id name="wydarzenieId" type="integer" column="_wydarzenie_id"/>
    <id name="uzytkownikId" type="integer" column="_uzytkownik_id"/>
    <field name="lajkData" type="datetime" column="_lajk_data"/>
    <lifecycle-callbacks/>
  </entity>
</doctrine-mapping>

我必须做什么才能让它工作?我是自己写实体还是我只是要改变一些东西?

【问题讨论】:

  • “但我仍然没有成功地重新生成它”是什么意思?你如何“再生实体”?

标签: php sql symfony doctrine


【解决方案1】:

我猜你说的是command line tool,它从注释中生成类和代理。通常该工具不是很好。它在继承方面存在很多问题,而且在您的情况下似乎使用复合(not dual)键。

尝试手动更正实体类中的注释,不要使用该工具。如果你想用它这么糟糕,只在第一次生成所有东西,纠正工具无法解决的错误,忘记那个工具曾经存在过:)

顺便说一句。尽管 Doctrine 支持复合键,但不鼓励使用它们。因此,如果它们不是真正必要的,请不要使用它们。请参阅documentation

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-06-17
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多