Реализация пакета ongr-io эластичного поиска с доктриной Symfony2

В нашем проекте symfony2 мы хотим реализовать эластичный поиск с пакетом ongr-io, но вся наша система построена на доктрине. Можно ли каким-либо образом использовать пакет ongr-ioasticsearch без полной переделки всей базы данных с документами вместо сущностей?

Сущность, которую я хочу проиндексировать (поля для поиска будут: name, ChildCategory и ParentCategory):

/**
* Course
*
* @ORM\Table(name="course")
* @ORM\Entity(repositoryClass="CoreBundle\Repository\CourseRepository")
* @ORM\HasLifecycleCallbacks
*/
class Course
{
/**
* @var int
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;

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

/**
* @var ParentCategory
*
* @ORM\ManyToOne(targetEntity="ParentCategory")
* @ORM\JoinColumn(name="parentCategory_id", referencedColumnName="id")
*/
private $parentCategory;

/**
* @var ChildCategory
*
* @ORM\ManyToOne(targetEntity="ChildCategory", inversedBy="courses")
* @ORM\JoinColumn(name="childCategory_id", referencedColumnName="id")
*/
private $childCategory;

/**
* @var City
*
* @ORM\ManyToOne(targetEntity="City")
* @ORM\JoinColumn(name="city_id", referencedColumnName="id")
*/
private $city;

/**
* @var Users
*
* @ORM\ManyToOne(targetEntity="UserBundle\Entity\Users", inversedBy="course")
* @ORM\JoinColumn(name="owner_id", referencedColumnName="id")
*/
private $owner;

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

/**
* @var Picture
*
* @ORM\OneToMany(targetEntity="CoreBundle\Entity\Picture", mappedBy="course", cascade={"persist", "remove"})
*/
private $pictures;

/**
* @var Ratings
*
* @ORM\OneToMany(targetEntity="CoreBundle\Entity\Ratings", mappedBy="courseid")
*/
private $ratings;

public $avgRating;
}

1

Решение

это очень интересно.

Первым делом это местоположение сущности. Документ для ElasticsearchBundle должен быть в Document каталог. Это не имеет большого значения. Все, что вам нужно сделать, это создать пустой класс и расширить сущность с помощью @Document аннотаций. Далее идут поля. С name поле нет проблем вообще, просто добавьте @property аннотации и ты хороший. Интереснее отношения. Моим предложением было бы создать отдельное свойство и в получателе возвращаемое значение из отношения для этого поля. Я надеюсь, у вас есть идея.

Обновить:

Вот пример документов:

AppBundle / Entity / Post

<?php

namespace AppBundle\Entity;

use Doctrine\ORM\Mapping as ORM;
use ONGR\ElasticsearchBundle\Annotation as ES;

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

/**
* @var string
*
* @ES\Property(type="string")
* @ORM\Column(name="title", type="string", length=255, nullable=true)
*/
private $title;

/**
* @var User
*
* @ORM\ManyToOne(targetEntity="User")
* @ORM\JoinColumn(name="user_id", referencedColumnName="id")
*/
private $user;

/**
* @var string
*
* @ES\Property(name="user", type="string")
*/
private $esUser;

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

/**
* Set title
*
* @param string $title
*
* @return Post
*/
public function setTitle($title)
{
$this->title = $title;

return $this;
}

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

/**
* Set user
*
* @param \AppBundle\Entity\User $user
*
* @return Post
*/
public function setUser(\AppBundle\Entity\User $user = null)
{
$this->user = $user;

return $this;
}

/**
* Get user
*
* @return \AppBundle\Entity\User
*/
public function getUser()
{
return $this->user;
}

/**
* @return string
*/
public function getEsUser()
{
return $this->esUser;
}

/**
* @param string $esUser
*/
public function setEsUser($esUser)
{
$this->esUser = $esUser;
}
}

AppBundle / Документ / Post

<?php

namespace AppBundle\Document;

use ONGR\ElasticsearchBundle\Annotation as ES;
use AppBundle\Entity\Post as OldPost;

/**
* @ES\Document()
*/
class Post extends OldPost
{
}
0

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]