Order と Shipment の 2 つのエンティティだけを持つ小さなアプリケーションを作成しています。
Shipment エンティティは次のとおりです: (短くするためにメソッドは削除されています)
/**
* @var integer $id
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;
/**
* @var string $username
*
* @ORM\Column(name="username", type="string", length=255)
*/
private $username;
/**
* @var string $password
*
* @ORM\Column(name="password", type="string", length=255)
*/
private $password;
/**
* @var integer $order_id
*
* @ORM\Column(name="order_id", type="integer")
*/
private $order_id;
/**
* @var smallint $payment_type
*
* @ORM\Column(name="payment_type", type="smallint")
*/
private $payment_type;
コントローラーで を使用してクエリを実行しようとしていますorder_id
が、findOneByOrderId
メソッドが機能していません。
$orderExists = $this->getDoctrine()
->getRepository('ShipBundle:Shipment')
->findOneByOrderId($orderId);
var_dump($orderExists); die();
私が得るエラーは次のとおりです。
Entity 'ShipBundle\Entity\Shipment' has no field 'orderId'. You can therefore not call 'findOneByOrderId' on the entities' repository.
私が間違っていなければ、Doctrinefind
メソッドは変数をアンダースコアで結合し、それらを大文字にします。私は何を間違っていますか?