Hazırda findByExample yöntemi gibi doktrinde bir yöntem var mı?
teşekkürler
Sen miras ve tüm depolarda mevcut olduğunu findBy () yöntemini kullanabilirsiniz.
Örnek:
$criteria = array('name' => 'someValue', 'status' => 'enabled');
$result = $em->getRepository('SomeEntity')->findBy($criteria);
Böyle bir tanım kullanarak depolarından biri olarak findByExample () yöntemi oluşturabilirsiniz:
class MyRepository extends Doctrine\ORM\EntityRepository {
public function findByExample(MyEntity $entity) {
return $this->findBy($entity->toArray());
}
}
Bu çalışması için, size ToArray () yöntemini uygulamak, varlıklar için kendi temel sınıf oluşturmak zorunda olacak. MyEntity Ayrıca özel kişiler (yine toArray () yöntemi) uygulamak zorunda olacak bir arayüz olabilir.
, Tüm depolarda bu kullanılabilir hale sizin temel depo sınıfını genişleterek emin olmak için - bu örnekte, MyRepository biri.
P.S I assume you are talking about Doctrine 2.x
Evet.
Diyelim ki Kullanıcıları adında bir modeli var diyelim. Aşağıdaki iki sınıfları var
abstract class Base_User extends Doctrine_Record
{
//define table, columns, etc
}
class User extends Base_User
{
}
bazı diğer nesne yapabileceğiniz
$user = new User;
//This will return a Doctrine Collection of all users with first name = Travis
$user->getTable()->findByFirstName("Travis");
//The above code is actually an alias for this function call
$user->getTable()->findBy("first_name", "Travis");
//This will return a Doctrine Record for the user with id = 24
$user->getTable()->find(24);
//This will return a Doctrine Collection for all users with name=Raphael and
//type = developer
$user->getTable()
->findByDql("User.name= ? AND User.type = ?", array("Raphael", "developer"));
$users = $userTable->findByIsAdminAndIsModeratorOrIsSuperAdmin(true, true, true);
Bkz http://www.doctrine-project.org/projects/orm/1.2/docs/manual/dql-doctrine-query-language/en