проблема присоединения к доктрине 2 [с помощью картографов xml] - PullRequest
2 голосов
/ 18 апреля 2011

Я пытаюсь объединить две таблицы, но застреваю при написании правильных картографов xml (настройка и доступ к объектам проверены и работают нормально)

  • На основе MySQL, Doctrine 2.0.4 и ZF-1.11
  • Я использую XmlDriver ('path \ to \ mappers);

Запрос

$query = $em->createQueryBuilder()
    ->select('u')
    ->from('\Entities\Users', 'u')
    ->leftJoin('u.Addresses', 'a')
    ->getQuery();
$info = $query->getResult();

Mapper

<?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="Entities\Users" table="users">

    <change-tracking-policy>DEFERRED_IMPLICIT</change-tracking-policy>

    <id name="id" type="integer" column="id">
      <generator strategy="IDENTITY"/>
    </id>

    <field name="name" type="string" column="name"/>

    <many-to-one field="street" target-entity="Addresses" />

  </entity>
</doctrine-mapping>

Но со всеми возможными связями (я здесь устаю :) У меня всегда возникает одна и та же проблема: свойство связанной сущности не найдено:

Doctrine \ ORM\ Mapping \ MappingException - свойство улицы не существует

1 Ответ

0 голосов
/ 09 мая 2011

Вы указали целевой объект для своего поля улицы, но Вы должны предоставить отображение обратно в таблицу объектов назначения, в данном случае «Адреса». Используя Doctrine 2 XML Mapping это будет:

<many-to-one field="street" target-entity="Addresses" inversed-by="id" />

Предполагается, что столбец идентификаторов в вашей таблице адресов называется «id».

...