Как получить количество комментариев к записи для отображения в списке внутренних сообщений? - PullRequest
0 голосов
/ 19 апреля 2011

Если это поможет, вот моя схема для сообщений и комментариев:

BlogPost:
  actAs:
    Timestampable: ~
    I18n:
      fields: [title, body]
  tableName: blog_posts
  columns:
    #id: { type: integer(4), primary: true, autoincrement: true }
    user_id: { type: integer }
    title: { type: string(255) }
    body: { type: text }
  relations:
    User:
      type: one
      class: sfGuardUser
      local: user_id
      foreign: id
    Comments:
      type: many
      class: BlogComment
      local: id
      foreign: post_id

BlogComment:
  actAs:
    Timestampable: ~
  tableName: blog_comments
  columns:
    #id: { type: integer(4), primary: true, autoincrement: true }
    post_id: { type: integer }
    user_id: { type: integer }
    body: { type: text }
  relations:
    Post:
      type: one
      class: BlogPost
      local: post_id
      foreign: id

Вот мой класс Post Query:

class BlogPostQuery extends Doctrine_Query {

        /**
         *
         * @param Doctrine_Connection $conn
         * @param string $class
         * @return BlogPostQuery
         */
        public static function create($conn = null, $class = null) {
            return parent::create($conn, 'BlogPostQuery')
                    ->from('BlogPost p');
        }

        /**
         *
         * @param string $fields
         * @return BlogPostQuery
         */
        public function addSelf($fields = 'p.*') {
            return $this
            ->addSelect($fields);
        }

        /**
         *
         * @param string $fields
         * @return BlogPostQuery
         */
        public function addUsers($fields = 'u.*') {
            return $this
            ->addSelect($fields)
            ->innerJoin('p.User u')
            ->addGroupBy('u.id');
        }

        /**
         *
         * @param string $fields
         * @return BlogPostQuery
         */
        public function addComments($fields = 'pc.*') {
            return $this
            ->addSelect($fields)
            ->leftJoin('p.Comments pc')
            ->addGroupBy('p.id');
        }


        public function addCommentsCount($alias = 'nb_comments') {
            return $this
            ->addSelect(sprintf('COUNT(pc.id) as %s', $alias))
            ->addGroupBy('p.id');
        }
     }

Вот мой класс Post Table:

class BlogPostTable extends Doctrine_Table
{
    /**
     * Returns an instance of this class.
     *
     * @return object BlogPostTable
     */
    public static function getInstance()
    {
        return Doctrine_Core::getTable('BlogPost');
    }

    public static function findAllWithCountComments() {   
        return BlogPostQuery::create()
                ->addSelf()
                ->addUsers()
                ->addComments()
                ->addCommentsCount()
                ->execute();
    }

}

Так в файле generator.yml в конфиге списка я пишу:

list:
        title: Blog Posts Managment
        display: [id,title,User,nb_comments]
        table_method: findAllWithCountComments

Но идентификатор не работает и выдает ошибку:

Неизвестное свойство записи /связанный компонент "nb_comments" в "BlogPost"

Также существует слишком много запросов к БД.

Итак, как преодолеть эту ошибку и получить количество комментариев для каждого сообщения?

1 Ответ

0 голосов
/ 19 апреля 2011

Вам необходимо добавить метод в класс BlogPost для nb_comments

// BlogPost class
public function getNbComments()
{
    // return number of comments
}

См. Раздел «Пользовательские поля» в http://www.symfony -project.org / gentle-вводный / 1_4 / ru /14-Admin-генератор

...