0

我是 Symfony 的新手,我正在尝试运行基本的 SQL 查询,但不断收到以下错误。我很难解决这个问题。我想知道是否有人可以指出我正确的方向并可能解释我做错了什么?

提前谢谢了!

错误:

Call to Undefined Method ... DefaultController::getEntityManager()

实体(Company.php)

namespace Foo\FooBundle\Entity;
use Doctrine\Common\Annotations\AnnotationReader;
use Doctrine\ORM\Mapping as ORM;
use Doctrine\ORM\EntityRepository;

 /**
 *@ORM\Entity
 *@ORM\Table(name="company")
 */
class Company extends EntityRepository
{
   /**
     *@ORM\id
     *@ORM\Column(type="integer")
     *@ORM\GeneratedValue(strategy="AUTO")
     */
    protected $id;

    /**
    *@ORM\Column(type="string", length=250)
    */
    protected $name;

    /**
    *@ORM\Column(type="string", length=650)
    */
    protected $description;
}

控制器

public function searchAction($word)
{
        $stmt = $this->getEntityManager()->getConnection()->prepare("SELECT * FROM company WHERE 
     MATCH(`keywords`) AGAINST(':word' IN BOOLEAN MODE)");
                  $stmt->bindValue('word ', $word);
                  $stmt->execute();
                  $results = $stmt->fetchAll();

    ..etc, etc....      
4

1 回答 1

3

正如touki在评论中所说,

您应该从教义中获得经理:

$em = $this->getDoctrine()->getManager();

我看到您发布了许多关于 symfony2 的问题,尝试制作一个测试项目并生成实体,并为其生成 CRUD。

php app/console doctrine:generate:entity
php app/console doctrine:generate:crud

生成的代码将帮助您了解它的工作原理

于 2013-10-04T13:57:42.810 回答