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

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

Объект, который я хочу проиндексировать (поля для поиска будут: 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
{
}
Другие вопросы по тегам