私は 2 つのエンティティ Beverage と Beer を使用します。それぞれに独自のエンティティ マネージャがあります。ビールは冷ややかで、飲み物は冷凍庫にあります。私の戦略は、両方のタイプのエンティティのリストを取得し、飲料側でそれらをペアにして、それらを一致させることです。単一のエンティティに対して同様の機能が存在します。ただし、エンティティのリストを処理する場合は、それらを一括で処理する必要があります。そうしないと、追加のクエリFOR EACH ENTITY ON THE LISTが必要になります。これは悪いです。
以下は、すべての重要でない部分が取り除かれていると思います。これは苦痛で面倒なアプローチです。ドクトリンオームでスキーマを指定できるため、スキーマベースのアプローチに行くことでそれを放棄することができました。ただし、このコードは私のために仕事をしました。
あなたは繰り返し警告されてきました (実際には、他の Q&A ペアで私からです)。
結婚機能を取得するためにコントローラーを拡張する必要があるスーパーコントローラー。
<?php
namespace beverage\beverageBundle\Controller;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
class ThawController extends Controller
{
public static function defrost( $controller, $beverages ) {
$em = $controller->getDoctrine()->getManager( 'frosty' );
$beverageIds = array();
foreach ( $beverages as $k =>$v ) {
array_push( $beverageIds, $v->getIceid() );
}
$qb=$em->getRepository( 'frostyfrostyBundle:Beer' )
->createQueryBuilder( 't' )
;
if ( array() == $beverageIds ) {return null;}
$qbeers=$qb->where( $qb->expr()
->in( 't.id', $beverageIds ) )
->getQuery()
->getResult();
foreach ( $qbeers as $k => $beer ) {
$id=$beer->getId();
$beers[$id]=$beer;
}
foreach ( $beers as $k => $beer ) {
}
foreach ( $beverages as $k => $beverage ) {
$beverage->ice( $beers[$beverage->getIceid()] );
}
return $beverages;
}
public static function thaw( $controller, $beverage ) {
$beer= null;
$em = $controller->getDoctrine()->getManager( 'frosty' );
$beer=$em->getRepository( 'frostyfrostyBundle:Beer' )
->createQueryBuilder( 't' )
->where( 't.id = '.$beverage->getIceid() )
->getQuery()
->getSingleResult();
$beverage->ice( $beer );
return $beverage;
}
}
およびエンティティ コード:
<?php
namespace freezer\freezerBundle\Entity;
use Doctrine\ORM\Mapping as ORM;
use frosty\frostyBundle\Entity\Beer as beer;
class Student {
private $id;
private $iceid;
public function getId() {
return $this->id;
}
public function setIceid( $iceid ) {
$this->iceid = $iceid;
return $this;
}
public function getIceid() {
return $this->iceid;
}
public function __construct( beer $beer=null
, $manyToMany = null ) {
if ( $beer instanceof \frosty\frostyBundle\Entity\Beer ) {
$this->ice( $beer, $manyToMany );
}
}
public function setBeer( \frosty\frostyBundle\Entity\Beer $beer=null){
$this->beer = $beer;
return $this;
}
public function getBeer() {
return $this->beer;
}
public function ice( snowflake $snowflake=null
, $manyToMany = null ) {
if ( $snowflake instanceof
\frosty\frostyBundle\Entity\Beer ) {
$methods=get_class_methods( get_class( $snowflake ) );
$methods=array_filter( $methods
, function( $item ) use ( &$methods ) {
next( $methods );
if ( "__" == substr($item 0,2))
return false;
if ( "remove" == substr($item,0,6))
return false;
if ( "get" == substr($item,0,3))
return false;
return true;
} );
$amethods=array_filter( $methods
, function( $item ) use ( &$methods ) {
next( $methods );
if ( "set" == substr($item,0,3))
return false;
return true;
} );
$methods=array_filter( $methods
, function( $item ) use ( &$methods ) {
next( $methods );
if ( "add" == substr($item,0,3))
return false;
return true;
} );
foreach ( $methods as $k => $v ) {
$this->{$v}( $snowflake->{str_replace( "set"
, "get"
, $v )}() );
}
foreach ( $amethods as $k => $v ) {
if ( $manyToMany ) {
$results=$snowflake->{str_replace( "add"
, "get"
, $v )}();
foreach ( $results as $key =>$value ) {
$this->{$v}( $value );
}
}
}
$this->setIceid( $beer>getId() );
}
}
}