Мое объединение выглядит следующим образом в 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;
}
}