Как создать объект с помощью Symfony2

Мой общий вопрос: как создать сущности и репозитории с помощью symfony2?

  • Как создать объект/репозиторий с помощью schema.yml с доктриной orm? Где я должен сохранить файл schema.yml? Каковы команды для ввода в консоль?
  • Я создаю объект класса без schema.yml, что делать после? Команда!?
  • Где я должен сохранить файл объекта/репозитория, когда сущность является общей для всего проекта или связана с пакетом?

Ответы

Ответ 1

Мои решения (я не знаю, хорошо ли это, передовая практика!?)

YML

Создайте файл Entities.User.dcm.yml в HelloBundle/Resources/config/doctrine/metadata/orm с помощью этого кода (на примере):

Entities\User:
  type: entity
  table: users
  id:
    id:
      type: integer
      generator:
        strategy: AUTO
  fields:
    name:
      type: string
      length: 50

Тогда

php app/console doctrine:mapping:import "HelloBundle" yml

php app/console doctrine:generate:entities "HelloBundle"

Затем вы можете протестировать его в своем контроллере с помощью

$user = new \Sensio\HelloBundle\Entity\User;
$user->setName('Acubens');
$em = $this->get('doctrine.orm.entity_manager');
$em->persist($user);
$em->flush();

или PHP

Создайте файл User.php в HelloBundle\Entity с помощью этого кода

// Sensio/HelloBundle/Entity/User.php
namespace Sensio\HelloBundle\Entity;

/**
 * @orm:Entity
 */
class User
{
    /**
     * @orm:Id
     * @orm:Column(type="integer")
     * @orm:GeneratedValue(strategy="IDENTITY")
     */
    protected $id;

    /**
     * @orm:Column(type="string", length="255")
     */
    protected $name;
}

Тогда

php app/console doctrine:mapping:import "HelloBundle"

это будет генерироваться в "HelloBundle/Resources/config/doctrine/metadata/orm"

<?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="Sensio\HelloBundle\Entity\User" table="user">
    <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" length="255"/>
    <lifecycle-callbacks/>
  </entity>
</doctrine-mapping>

Затем удалить User.php

php app/console doctrine:generate:entities "HelloBundle"

После того, как у вас есть новый хороший файл User.php

<?php

namespace Sensio\HelloBundle\Entity;

/**
 * Sensio\HelloBundle\Entity\User
 */
class User
{
    /**
     * @var string $name
     */
    private $name;

    /**
     * @var integer $id
     */
    private $id;


    /**
     * Set name
     *
     * @param string $name
     */
    public function setName($name)
    {
        $this->name = $name;
    }

    /**
     * Get name
     *
     * @return string $name
     */
    public function getName()
    {
        return $this->name;
    }

    /**
     * Get id
     *
     * @return integer $id
     */
    public function getId()
    {
        return $this->id;
    }
}

И как вы это делаете? Почему я должен указывать HelloBundle в моих командах?

ps: my config.yml

doctrine.dbal:
    driver:   pdo_mysql
    dbname:   sf2
    user:     root
    password: 
    logging:  %kernel.debug%
doctrine.orm:
    auto_generate_proxy_classes: %kernel.debug%
    mappings:
        HelloBundle: ~

Ответ 2

Если вы используете аннотацию YML для создания вашей схемы, вы можете получить следующее:

Namespace\NameBundle\Entity\Build:
  type: entity
  repositoryClass: Namespace\NameBundle\Entity\Repository\BuildRepository
  ...

при использовании командной строки app/console doctrine: generate: entities NamespaceNameBundle Это автоматически сгенерирует ваш объект и класс репозитория.

Ответ 3

http://docs.symfony-reloaded.org/guides/doctrine/orm/index.html

В этом разделе должна быть вся необходимая информация.

Хотя Symfony2 сейчас находится на стадии стабилизации, в последнем выпуске PR6 все еще есть много недостающих функций, и, скорее всего, ситуация изменится в версии RC1. Не бойтесь погрузиться в код и понять, что вы делаете.

Ответ 4

Я искал решение с использованием YML-сопоставления, так как его нигде не было найдено в книге. После небольшого перебора я обнаружил, что ваши сопоставления должны следовать этим правилам:

  • файл должен быть помещен в src/YourAppName/YourBundleName/Resources/config/doctrine/EntityName.orm.yml
  • имя класса сущности должно быть заполнено (например: YourAppName\YourBundleName\Entity\EntityName

Надеюсь, это поможет.

Ответ 5

Я думаю, что вы должны выбрать между созданием класса или настройкой yml. Если вы создаете класс сущности и файл конфигурации yml, а затем выполняете doctrine: generate: entities У вас есть ошибка. Я рекомендую вам придерживаться стиля класса с помощью анотаций, а затем использовать $ php app/console doctrine: database: create $ php app/console doctrine: schema: create