2016-08-24 6 views
0

エンティティに関してDoctrine Requestを正しく構築する方法。 おはようございます。 Symfonyにはほとんど問題がありません。エンティティに関してDoctrine Requestを正しく構築する方法

質問は「上部コードを修正する方法」です。

お知らせ:未定義のプロパティ:教義\ ORM \ QueryBuilder :: $ getQuery

スタックトレース:

in src/enterBundle/Controller/DefaultController.php at line 131 - 
          ->select('user.id','user.username','user.password','user.token') 
          ->where('user.username=:userName')->setParameter('userName',$login) 
          ->where('user.password=:Pass')->setParameter('Pass',$password) 
          ->getQuery 
          ->getResult(Query::HYDRATE_ARRAY); 

エンティティ:

<?php 

namespace enterBundle\Entity; 

use Doctrine\ORM\Mapping as ORM; 

/** 
* users 
* 
* @ORM\Table(name="users") 
* @ORM\Entity(repositoryClass="enterBundle\Repository\usersRepository") 
*/ 
class users 
{ 
    /** 
    * @var int 
    * 
    * @ORM\Column(name="id", type="integer") 
    * @ORM\Id 
    * @ORM\GeneratedValue(strategy="AUTO") 
    */ 
    private $id; 




    /** 
    * @var string 
    * 
    * @ORM\Column(name="username", type="string", length=777, unique=true) 
    */ 
    private $username; 

    /** 
    * @var string 
    * 
    * @ORM\Column(name="password", type="string", length=999) 
    */ 
    private $password; 

    /** 
    * @var string 
    * 
    * @ORM\Column(name="token", type="text") 
    */ 
    private $token; 


    /** 
    * Get id 
    * 
    * @return int 
    */ 
    public function getId() 
    { 
     return $this->id; 
    } 

    /** 
    * Set username 
    * 
    * @param string $username 
    * 
    * @return users 
    */ 
    public function setUsername($username) 
    { 
     $this->username = $username; 

     return $this; 
    } 

    /** 
    * Get username 
    * 
    * @return string 
    */ 
    public function getUsername() 
    { 
     return $this->username; 
    } 


    /** 
    * Set password 
    * 
    * @param string $password 
    * 
    * @return users 
    */ 
    public function setPassword($password) 
    { 
     $this->password = $password; 

     return $this; 
    } 

    /** 
    * Get password 
    * 
    * @return string 
    */ 
    public function getPassword() 
    { 
     return $this->password; 
    } 

    /** 
    * Set token 
    * 
    * @param string $token 
    * 
    * @return users 
    */ 
    public function setToken($token) 
    { 
     $this->token = $token; 

     return $this; 
    } 

    /** 
    * Get token 
    * 
    * @return string 
    */ 
    public function getToken() 
    { 
     return $this->token; 
    } 
} 

質問が正しくcreateQueryBuilderを使用する方法であります? p.s.未定義のプロパティ:教義\ ORM \ QueryBuilder :: $ getQuery

はあなたがここにコードチェック:

//... 
->getQuery // <--- missing() 
->getResult(Query::HYDRATE_ARRAY); 

質問はどのようにある私はsymfony

答えて

4

お知らせして新たなんですcreateQueryBuilderを正しく使用しますか?

このロジックをリポジトリメソッド内に作成することをお勧めします。

まず、あなたのユーザリポジトリクラスの作成:

// src/AppBundle/Repository/UserRepository.php 

class UserRepository extends EntityRepository 
{ 
    public function findUser($username, $password) 
    { 
     return $this->createQueryBuilder('user') 
        ->select('user.id','user.username','user.password','user.token') 
        ->where('user.username = :username')->setParameter('username', $username) 
        ->andWhere('user.password = :pass')->setParameter('pass', $password) 
        ->getQuery() 
        ->getArrayResult(); 
    } 
} 

注二where文を、これはandWhereorWhereが、そうでない場合は最初のwhere文を置き換えます、考慮しなければなければなりません。

第二に、あなたのエンティティにリポジトリを関連付ける:

/** 
* @ORM\Table() 
* @ORM\Entity(repositoryClass="AppBundle\Repository\UserRepository") 
*/ 
class User 
{ 
    //... 
} 
+0

私はすでにそれを持ってあなたがた:D – fonjeekay

関連する問題