Как мне воспроизвести это СОЕДИНЕНИЕ с Doctrine 2? - PullRequest
0 голосов
/ 17 ноября 2011

Мое объединение выглядит следующим образом в sql:

   SELECT m.* 
     FROM settings AS s 
LEFT JOIN modules AS m on s.name = m.module 
    WHERE s.value = 1 
      AND s.category = 'module_status'

Я не могу понять, как воспроизвести это в Учении 2. Любая помощь очень ценится!

Вот мои сущности:

namespace Entities;
use Doctrine\Common\Collections\ArrayCollection;

/**
 * Modules
 *
 * @Table(name="modules")
 * @Entity(repositoryClass="Repositories\Modules")
 */
class Modules
{
    /**
     * @var integer $id
     *
     * @Column(name="id", type="integer", nullable=false)
     * @Id
     * @GeneratedValue(strategy="IDENTITY")
     */
    private $id;

    /**
     * @var string $module
     * @Column(name="module", type="string", length=255, nullable=false)
     */
    private $module;

    /**
     * @var string $label
     * @Column(name="label", type="string", length=255, nullable=false)
     */
    private $label;

    /**
     * @var string $package
     *
     * @Column(name="package", type="string", length=255, nullable=true)
     */
    private $package;

    /**
     * @var string $path
     *
     * @Column(name="path", type="string", length=255, nullable=true)
     */
    private $path;

    /**
     * @var float $version
     *
     * @Column(name="version", type="float", nullable=false)
     */
    private $version;

    public function getId() {
        return $this->id;
    }

    public function getModule() {
        return $this->module;
    }

    public function getLabel() {
        return $this->label;
    }

    public function getPackage() {
        return $this->package;
    }

    public function getPath() {
        return $this->path;
    }

    public function getVersion() {
        return $this->version;
    }

    public function setId($id) {
        $this->id = $id;
    }

    public function setModule($module) {
        $this->module = $module;
    }

    public function setLabel($label) {
        $this->label = $label;
    }

    public function setPackage($package) {
        $this->package = $package;
    }

    public function setPath($path) {
        $this->path = $path;
    }

    public function setVersion($version) {
        $this->version = $version;
    }


}



namespace Entities;


use Doctrine\ORM\Mapping as ORM;

/**
 * Settings
 *
 * @Table(name="settings")
 * @Entity(repositoryClass="Repositories\Settings")
 */
class Settings
{
    /**
     * @var integer $id
     *
     * @Column(name="id", type="integer", nullable=false)
     * @Id
     * @GeneratedValue(strategy="IDENTITY")
     */
    private $id;

    /**
     * @var string $name
     *
     * @Column(name="name", type="string", length=255, nullable=true)
     */
    private $name;

    /**
     * @var string $category
     *
     * @Column(name="category", type="string", length=255, nullable=true)
     */
    private $category;

    /**
     * @var text $value
     *
     * @Column(name="value", type="text", nullable=true)
     */
    private $value;

    public function getId() {
        return $this->id;
    }

    public function getName() {
        return $this->name;
    }

    public function setName($name) {
        $this->name = $name;
    }

    public function getCategory() {
        return $this->category;
    }

    public function setCategory($category) {
        $this->category = $category;
    }

    public function getValue() {
        return $this->value;
    }

    public function setValue($value) {
        $this->value = $value;
    }
}

Ответы [ 2 ]

3 голосов
/ 17 ноября 2011

Во-первых, вам нужно настроить связь между объектами «Настройки» и «Модули». Я предполагаю, что отношения между этими двумя являются многими ко многим:

Class Modules
{
    /**
     * @ManyToMany(targetEntity="Settings", inversedBy="modules")
     * @JoinTable(name="modules_settings")
     */
    private $settings;
}

Class Settings
{
    /**
     * @ManyToMany(targetEntity="Modules", mappedBy="settings")
     */
    private $modules;
}

Тогда ваш синтаксис запроса будет выглядеть так:

$qb->select('s', 'm')
   ->from('Entities\Settings', 's')
   ->leftJoin('s.modules')
   ->where('s.value = 1');

Я не могу сказать, что происходит в предложении AND, но если то, что у вас есть, правильно, то вы просто добавляете эту строку в конец вашего запроса:

->andWhere('s.category = m.status');
1 голос
/ 18 ноября 2011

Спасибо за помощь.Вот как закончился запрос:

$qb = $this->_em->createQueryBuilder()
   ->select('m')
   ->from('Entities\Modules', 'm')
   ->leftJoin('m.settings', 's')
   ->where('s.value = :enabled')
   ->andWhere('s.category = :moduleStatus')
   ->setParameter('moduleStatus', 'module_status')
   ->setParameter('enabled', 1)
   ->getQuery();

Вот как я настроил сущность модулей:

/**
* @OneToOne(targetEntity="Entities\Settings")
* @JoinColumn(name="module", referencedColumnName="name")
*/
private $settings;
...